在项目scheduled下找到入口程序ScheduledApplication添加注解@EnableScheduling
举几个例子如下:
“0 0 12 * * ?” 每天中午十二点触发
“0 30 10 ? * *” 每天早上10:30触发
“0 15 10 * * ?” 每天早上10:15触发
“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秒,测试下间隔输出的时间是多少,启动项目,并且查看控制台输出内容:
可以看到每一次打印的间隔都是2秒钟,也就是配置线程休眠的时间,证实了该方法并没有等到执行完再开始下一次执行。
fixedDelay属性
fixedDelay属性的效果与上面的fixedRate则是相反的,配置了该属性后会等到方法执行完成后延迟配置的时间再次执行该方法。
控制台输出
可以看到控制台打印,时间间隔是4秒钟,我们在方法内仅仅使线程休眠了3秒钟,配置方法的延迟执行时间则是1秒钟,证明在方法执行完成后延迟配置时间后再次执行该方法。
initialDelay属性
initialDelay属性跟上面的fixedDelay、fixedRate有着密切的关系,该属性的作用是第一次执行延迟时间,只是做延迟的设定,并不会控制其他逻辑,所以要配合fixedDelay或者fixedRate来使用。
重启项目,查看控制台输出,等待了10秒钟后才看到了第一次打印内容
项目成功启动的时间为11:26:12而第一次输出的时间则是11:26:22,证明配置的延迟时间生效了,第一次加载完成之后每间隔2秒钟执行该方法
本章主要学习基于SpringBoot内置的定时任务的配置使用,主要涉及两个注解,四个属性的配置:
- 主程序入口@EnableScheduling 开启定时任务
- 定时方法上@Scheduled设置定时
- cron属性 按cron规则执行
- fixedRate属性 以固定速率执行
- fixedDelay属性 上次执行完毕后延迟再执行
- initialDelay属性 第一次延时执行,第一次执行完毕后延迟后再次执行