时间:2022-10-04 10:50:30 | 栏目:JAVA代码 | 点击:次
一个定时器类中有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定时任务,每隔半小时要执行一次。
由于种种原因,昨晚上这台服务器被关机了,今早【重启服务器】和【启动定时任务服务】。
机器重启后,发现服务器机器系统时间和实际北京时间不一致,相差10个小时。
于是乎,我使用date -s 10:35:35 设置和北京时间保持一致。
本以为这样,时间已经一致了,定时任务应该能正常执行了!
等了好几个小时,定时任务依然没有执行。
于是查看系统日志,系统日志一切正常,只是没有定时任务执行的log日志。
奇了个怪,服务正常启动,但定时任务没有执行。
然而昨天还在跑的服务,就因为一次关机,就over了?
不可能,于是关掉应用服务再次重启。
定时任务执行成功了,于是得出结论: 服务器系统时间改变后,Spring 定时任务将失效。
服务器系统时间改变后,Spring 定时任务将失效,解决方法就是:重启应用服务。