开发者社区> 问答> 正文

为何Executors创建的定时任务会自动停止

我在网站后台添加一个定时任务,方式是Executors.new...创建,然后添加被执行的Runnable对象,每2个小时执行一次,现在发现大概两个月后定时任务会自动停止,而且没有任何异常抛出,求朋友帮忙分析下

展开
收起
长安归故里. 2020-01-07 13:14:49 1037 0
1 条回答
写回答
取消 提交回答
  • 不是很确定问题出现在哪里,但是可以做如下两件事情:

    1. 监控一下Queue:实际上Executors创建的是ScheduledThreadPoolExecutor这个类的对象,做强制类型转换然后调用 BlockingQueue getQueue() 这个方法,定时将Queue的数量输出到日志里面,看任务队列是否有变化;

    2. 监控RejectException:实际上默认的线程池有个个人认为很不好的地方,就是大家都习惯于使用Executors创建线程池,所以很多人都不知道线程池实际上有时候会拒绝掉一个任务的(具体算法不说了),而默认的处理方式是直接丢弃,解决的方法是直接使用public ScheduledThreadPoolExecutor(int corePoolSize, RejectedExecutionHandler handler)这个构造器,将拒绝掉的线程监控起来(比如记录到日志里面),这样就可以知道哪些任务是拒绝了的。

    以上No.1是看线程池是否还在正常工作,No.2是看是否任务有没有被正常执行(是否被抛弃了)。

    另外说一点,其实题主的需求比较适合使用Quartz来实现,个人觉得默认的ScheduledThreadPoolExecutor不是很好用,实现也比较复杂。

    2020-01-07 13:14:58
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载