java - spring 定时任务执行异常

查看:623
本文介绍了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任务却执行了。。。

解决方案

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

这篇关于java - spring 定时任务执行异常的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆