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

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

不是很确定问题出现在哪里,但是可以做如下两件事情:

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

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

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

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

用的 Executors.newScheduledThreadPool 吗??
你看看日志等的情况...

jstack看一下是不是线程死掉了或者是卡住了。