我在网站后台添加一个定时任务,方式是Executors.new...创建,然后添加被执行的Runnable对象,每2个小时执行一次,现在发现大概两个月后定时任务会自动停止,而且没有任何异常抛出,求朋友帮忙分析下
不是很确定问题出现在哪里,但是可以做如下两件事情:
监控一下Queue:实际上Executors创建的是ScheduledThreadPoolExecutor这个类的对象,做强制类型转换然后调用 BlockingQueue getQueue() 这个方法,定时将Queue的数量输出到日志里面,看任务队列是否有变化;
监控RejectException:实际上默认的线程池有个个人认为很不好的地方,就是大家都习惯于使用Executors创建线程池,所以很多人都不知道线程池实际上有时候会拒绝掉一个任务的(具体算法不说了),而默认的处理方式是直接丢弃,解决的方法是直接使用public ScheduledThreadPoolExecutor(int corePoolSize, RejectedExecutionHandler handler)这个构造器,将拒绝掉的线程监控起来(比如记录到日志里面),这样就可以知道哪些任务是拒绝了的。
以上No.1是看线程池是否还在正常工作,No.2是看是否任务有没有被正常执行(是否被抛弃了)。
另外说一点,其实题主的需求比较适合使用Quartz来实现,个人觉得默认的ScheduledThreadPoolExecutor不是很好用,实现也比较复杂。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。