本来每天周一到周五凌晨1点执行的任务,查看日志发现在周日20点执行了,求解可能发生的原因,服务器是单核cpu.
补充:我的定时任务类里有AB两个定时任务,A任务周一到周五1点执行(@Scheduled(cron = "0 0 1 ? MON-FRI")),B任务每天3点执行(@Scheduled(cron = "0 0 3 ? *")),查看日志发现在周一到周五时,先执行A任务而后执行了B任务,也就是B没有等到3点就执行了;当在周六周日是时B任务才是3点执行的,而周日20点A任务却执行了。。。
过去多啦不再A梦2017-05-17 10:04:53
我猜测你并没有指定定时任务的pool size,所以默认所有schedule的共用一个线程。需要指定schedule 的pool size大小
xml
<task :annotation-driven scheduler ="myScheduler" />
<task :scheduler id ="myScheduler" pool-size ="10" />
bean
@Bean(destroyMethod = "shutdown")
public Executor taskScheduler() {
return Executors.newScheduledThreadPool(10);
}
补充:
共用一个线程将带来严重的问题。如果A任务没有在2小时内执行完,那么B任务的执行时间将延后,甚至不执行。