springboot中部分定时器失效的问题

springboot中使用@Scheduled定时任务方法,有的参数有效但有的参数会失效。

比如@Scheduled(fixedRate = 30000),这种fixedRate的可以执行。

@Scheduled(cron = "8 40 16 * * ?"),这种每天固定时刻执行一次的,仅仅会在我运行程序后执行一次。

很邪门的是,同样是cron,@Scheduled(cron = "0 * * * * ?"),每分钟触发一次的,就可以每分钟正常执行下去。

当我把其他地方所有的@Scheduled都注释了,只留一个@Scheduled(cron = 8 40 16 * * ?"),更改系统时间多次测试,依然是只会在程序运行时触发一次,猜测应该不是性能问题。

@Scheduled注解上面都已经加了@Async("taskExecutor")
入口类里也加了@EnableAsync和@EnableScheduling,已经配置多线程了
也加了如下的配置类

img

你是先启动,然后去修改系统时间,这种是不会生效;因为springboot中的Scheduled在启动的时间,获取当前系统时间,然后自己去计算时间(仅仅是启动的时候获取一次时间,之后不再获取),这样做的目的,就是防止时钟回调,导致job多次执行

@Scheduled(cron = 8 40 16 * * ?")
你期望的运行周期是怎样的?

img


其实根本就没有失效,哪有你更改系统时间来做测试的。
你也说了每分钟一次是对的,那么就能证明定时任务是好的。你这个表达式是每天16小时40分8秒执行一次。该系统时间这种是不对的。至于为什么你再仔细想想,相信你会明白。

修改时间不行的,不是每秒都会去本地获取时间,打包发布服务器,挂两天看看日志

还是调试方式的问题,你在调试的时候可以
1.将cron表达式拿到一个可以在线测试cron表达式的网站,
2.看给你打印的信息是不是你想要的信息
3.如果是的话复制粘贴到@Scheduled(cron = "0 * * * * ?")注解内的cron表达式内

既然是每天某个时间执行一次,调试的时候先把corn时间改成当前往后的一两分钟就行了,调试好了再把corn改回去就好了,为啥想着去改系统时间