1.@Scheduled注解
常见参数:
1.fixedRate参数,传入一个时间间隔,单位是毫秒,这里是指每5s执行一次
@Scheduled(fixedRate = 5000)
public void testTask() {
//这里定义一个时间,方便观察注解对计划任务的具体作用
logger.info("每5s执行一次:时间{}", format.format(new Date()));
}
2.fixedDelay参数,传入一个以毫秒为单位的时间间隔
@Scheduled(fixedDelay = 5000)
public void testTask(){
logger.info("每5s执行一次:时间{}", format.format(new Date()));
}
前两个区别:(主要是快速重复和多线程要注意)
fixedDelay非常好理解,它的间隔时间是根据上次的任务结束的时候开始计时的。
比如一个方法上设置了fixedDelay=5*1000,那么当该方法某一次执行结束后,开始计算时间,
当时间达到5秒,就开始再次执行该方法。
fixedRate理解起来比较麻烦,它的间隔时间是根据上次任务开始的时候计时的。
比如当方法上设置了fiexdRate=5*1000,该执行该方法所花的时间是2秒,
那么3秒后就会再次执行该方法。
但是这里有个坑,当任务执行时长超过设置的间隔时长,那会是什么结果呢。
打个比方,比如一个任务本来只需要花2秒就能执行完成,我所设置的fixedRate=5*1000,
但是因为网络问题导致这个任务花了7秒才执行完成。当任务开始时Spring就会给这个任务计时,
5秒钟时候Spring就会再次调用这个任务,可是发现原来的任务还在执行,
这个时候第二个任务就阻塞了(这里只考虑单线程的情况下,多线程后面再讲),
甚至如果第一个任务花费的时间过长,还可能会使第三第四个任务被阻塞。
被阻塞的任务就像排队的人一样,一旦前一个任务没了,它就立马执行
3.cron参数,传递一个cron表达式,可以按照cron的逻辑执行代码
@Scheduled(cron = "0/5 * * * * ?")
public void testTask() {
logger.info("每5s执行一次:时间{}", format.format(new Date()));
}
每隔5秒执行一次: @Scheduled(cron = "*/5 * * * * ?")
每隔1分钟执行一次: @Scheduled(cron = "0 */1 * * * ?")
每天23点执行一次: @Scheduled(cron = "0 0 23 * * ?")
每天凌晨1点执行一次: @Scheduled(cron = "0 0 1 * * ?")
每月1号凌晨1点执行一次: @Scheduled(cron = "0 0 1 1 * ?")
每月最后一天23点执行一次: @Scheduled(cron = "0 0 23 L * ?")
每周星期天凌晨1点实行一次: @Scheduled(cron = "0 0 1 ? * L")
在26分、29分、33分执行一次: @Scheduled(cron = " 0 26,29,33 * * * ?")
每天的0点、13点、18点、21点都执行一次: @Scheduled(cron = " 0 0 0,13,18,21 * * ?")
0 0 10,14,16 * * ? 每天上午10点,下午2点,4点
0 0/30 9-17 * * ? 早晨9点到下午5点,每半小时执行一次
0 0 12 ? * WED 表示每个星期三中午12点
4.initialDelay 这个参数是指在任务开启后多少毫秒后执行,这里的代码意思是任务开启20s后,每5s执行一次
@Scheduled(fixedDelay = 5000,initialDelay = 20000)
public void testTask(){
logger.info("每5s执行一次:时间{}", format.format(new Date()));
}