spring定时器定时任务到时间未执行问题的解决
程序员文章站
2022-06-26 11:11:57
目录spring定时器定时任务到时间未执行应用场景原因分析解决方式解决修改系统时间后spring 定时任务不执行问题描述起因错误解决问题spring定时器定时任务到时间未执行应用场景一个定时器类中有n...
spring定时器定时任务到时间未执行
应用场景
一个定时器类中有n个定时任务,有每30秒执行一次的还有每1分钟执行一次的,出现问题的定时任务是0点整时执行的定时任务到了0点没有执行。
原因分析
spring定时器任务scheduled-tasks默认配置是单线程串行执行的,当某个定时任务出现阻塞,或者执行时间过长,则线程就会被占用,其他定时任务排队执行,导致后面的定时任务未能准时执行。
解决方式
开启多线程定时任务执行
/** * 多线程执行定时任务 */ @configurable public class scheduleconfig implements schedulingconfigurer { private static final int five = 5; @override public void configuretasks(scheduledtaskregistrar scheduledtaskregistrar) { scheduledtaskregistrar.setscheduler(executors.newscheduledthreadpool(five)); } }
解决修改系统时间后spring 定时任务不执行
问题描述
spring 定时任务不执行
事情起因是这样的,我们有一个spring定时任务,每隔半小时要执行一次。
起因
由于种种原因,昨晚上这台服务器被关机了,今早【重启服务器】和【启动定时任务服务】。
机器重启后,发现服务器机器系统时间和实际北京时间不一致,相差10个小时。
于是乎,我使用date -s 10:35:35 设置和北京时间保持一致。
错误
本以为这样,时间已经一致了,定时任务应该能正常执行了!
等了好几个小时,定时任务依然没有执行。
于是查看系统日志,系统日志一切正常,只是没有定时任务执行的log日志。
解决问题
奇了个怪,服务正常启动,但定时任务没有执行。
然而昨天还在跑的服务,就因为一次关机,就over了?
不可能,于是关掉应用服务再次重启。
定时任务执行成功了,于是得出结论: 服务器系统时间改变后,spring 定时任务将失效。
服务器系统时间改变后,spring 定时任务将失效,解决方法就是:重启应用服务。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。