SpringBoot使用Scheduled创建定时任务

SpringBoot使用Scheduled创建定时任务

四月 16, 2020

在项目下找到入口程序ScheduledApplication添加注解@EnableScheduling
这样会自动搜索@Compoment注解,并将其纳入spring bean管理
创建一个task的类

1
2
3
4
5
6
7
8
9
10
@Component
public class MyScheduledTask {
private Logger logger = LoggerFactory.getLogger(MyScheduledTask.class);

@Scheduled(cron = "1 * * * * ?")
public void task1(){
logger.info("定时任务1"+new Date());
}

}

打印日志如下

每分的01秒执行

cron属性

cron属性值是一个String类型的时间表达式,各部分的含义如下:
Seconds : 可出现”, - /”四个字符,有效范围为0-59的整数
Minutes : 可出现”, -
/”四个字符,有效范围为0-59的整数
Hours : 可出现”, - /”四个字符,有效范围为0-23的整数
DayofMonth : 可出现”, -
/ ? L W C”八个字符,有效范围为0-31的整数
Month : 可出现”, - /”四个字符,有效范围为1-12的整数或JAN-DEc
DayofWeek : 可出现”, -
/ ? L C #”四个字符,有效范围为1-7的整数或SUN-SAT两个范围。1表示星期天,2表示星期一,依次类推
Year : 可出现”, - * /”四个字符,有效范围为1970-2099年

举几个例子如下:
“0 0 12 ?” 每天中午十二点触发
“0 30 10 ? “ 每天早上10:30触发
“0 15 10 ?” 每天早上10:15触发
“0 15 10 ? 2018” 2018年的每天早上10:15触发
“0 14 ?” 每天从下午2点开始到2点59分每分钟一次触发
“0 0/5 14
?” 每天从下午2点开始到2:55分结束每5分钟一次触发
“0 0/5 14,18
?” 每天的下午2点至2:55和6点至6点55分两个时间段内每5分钟一次触发
“0 0-5 14
?” 每天14:00至14:05每分钟一次触发
“0 10,44 14 ? 3 WED” 三月的每周三的14:10和14:44触发
“0 15 10 ?
MON-FRI” 每个周一、周二、周三、周四、周五的10:15触发

fixedRate属性

fixedRate属性是上一个调用开始后再次调用的延时(不用等待上一次调用完成)

1
2
3
4
5
6
7
8
9
@Scheduled(fixedRate = 5*1000)
public void task1(){
try {
Thread.sleep(2*1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
logger.info("定时任务"+new Date());
}

打印如下

可以看到每一次打印的间隔都是5秒钟,也就是配置线程休眠的时间,证实了该方法并没有等到执行完再开始下一次执行。

fixedDelay属性

fixedDelay属性的效果与上面的fixedRate则是相反的,配置了该属性后会等到方法执行完成后延迟配置的时间再次执行该方法。

1
2
3
4
5
6
7
8
9
@Scheduled(fixedDelay = 5*1000)
public void task1(){
try {
Thread.sleep(2*1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
logger.info("定时任务"+new Date());
}

控制台输出

可以看到控制台打印,时间间隔是7秒钟,我们在方法内仅仅使线程休眠了2秒钟,配置方法的延迟执行时间则是5秒钟,证明在方法执行完成后延迟配置时间后再次执行该方法

initialDelay属性

initialDelay属性跟上面的fixedDelay、fixedRate有着密切的关系,该属性的作用是第一次执行延迟时间,只是做延迟的设定,并不会控制其他逻辑,所以要配合fixedDelay或者fixedRate来使用。

1
2
3
4
@Scheduled(initialDelay = 10*1000,fixedDelay = 5*1000)
public void task1(){
logger.info("定时任务"+new Date());
}

查看控制台输出,等待了10秒钟后才看到了第一次打印内容

总结

  1. 主程序入口@EnableScheduling 开启定时任务
  2. 定时方法上@Scheduled设置定时
  3. cron属性 按cron规则执行
  4. fixedRate属性 以固定速率执行
  5. fixedDelay属性 上次执行完毕后延迟再执行
  6. initialDelay属性 第一次延时执行,第一次执行完毕后延迟后再次执行