java - spring 定时任务执行异常
phpcn_u1582
phpcn_u1582 2017-05-17 10:02:53
[Java讨论组]

本来每天周一到周五凌晨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任务的执行时间将延后,甚至不执行。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号