基于注解的Spring定时任务配置

Spring版本5.1.5、JDK版本1.8

首先有一个定时的任务类

package com.yuanweiquan.learn.quartzs;

import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Component
public class MyQuartzs {
    @Scheduled(cron = "*/5 * * * * ?")//每五秒执行一次
    public void quartzs() {
        System.out.println(LocalDateTime.now().toString());
    }
}

XML配置



        
   //扫描包路劲
   
   //启用定时任务
   

启动Spring容器,控制台打印结果如下:

2019-03-29T15:15:30.011
2019-03-29T15:15:35.002
2019-03-29T15:15:40.001
2019-03-29T15:15:45.001
2019-03-29T15:15:50.001

5秒钟打印一次,刚好符合我们的需求。
但是如果我们的任务执行时间大于任务间隔时间5s,会怎么样呢?我们打印后设置一个休眠时间

public class MyQuartzs {
    @Scheduled(cron = "*/5 * * * * ?")
    public void quartzs() {
        System.out.println(LocalDateTime.now().toString());
        try {
            Thread.sleep(6000);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

再次启动spring容器,控制台打印结果如下:

2019-03-29T15:18:45.011
2019-03-29T15:18:55.001
2019-03-29T15:19:05.001

从打印结果可以看出来,任务10s执行了一次,而不是我们希望的5s。
原因是当定时任务准备执行时,发现上次任务还未执行完,就会再次等待休眠时间,再次执行,直到任务可以执行为止。

你可能感兴趣的:(spring)