webSphere下关闭项目后定时任务还在继续执行

 

一、问题描述

程序描述:程序中有一个定时任务(java.util.Timer)调用存储过程,一天调用一次,存储过程内部会插入"执行开始"和"执行结束"的记录到数据库的日志表中

问题描述:查看数据库日志表发现由原先的一天执行一次变成了一天执行两次

 

猜测中间有重启项目,关闭项目时定时任务未随之关闭

验证猜想

1、只关闭项目不关闭websphere ,发现定时任务依然执行

2、重启websphere后,将项目启动后关闭,然后再启动,定时任务执行两次 

以上验证结果可证实在websphere上停止项目,定时任务未停止的

 

二、问题产生原因

每个Timer对象要在后台启动一个线程。这种性质在一些托管的环境下不推荐使用,比如在应用服务器中。因为这些线程不在容器的控制范围之内了

 

三、解决方法

1.需要重启项目的时候 停止websphere再启动

或者

2.在服务销毁的时候调用定时器的cancel()方法 (例如:在servlet的destroy方法中调用定时器的cancel()方法)

 

posted @ 2022-10-20 17:20  harara  阅读(276)  评论(0)    收藏  举报