java - spring 定时任务执行异常
phpcn_u1582
phpcn_u1582 2017-05-17 10:02:53
0
1
991

本来每天周一到周五凌晨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任务却执行了。。。

phpcn_u1582
phpcn_u1582

全部回复(1)
过去多啦不再A梦

我猜测你并没有指定定时任务的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任务的执行时间将延后,甚至不执行。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板