搜索

首页  >  问答  >  正文

java - spring 定时任务执行异常

本来每天周一到周五凌晨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_u1582phpcn_u15822788 天前1055

全部回复(1)我来回复

  • 过去多啦不再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任务的执行时间将延后,甚至不执行。

    回复
    0
  • 取消回复