Java中Timer自动停止
问题描述
业务需要程序每隔10秒对数据进行一次操作,我使用Timer定时器实现此功能。这个功能在18年就已经上线了,但是昨天发现这个定时器在无人操作的情况下自己停止了。求问问题出现的原因以及解决方案。万分感谢!
具体情况
- 昨天没有人动过代码或数据库
- 程序没有报错(可能是出现了错误,但是没有输出到日志)
- 程序中其它的Timer定时器没有出现问题一直在正常执行
相关代码
Timer timer = new Timer();// 周期
long period = 10;// 每隔10秒钟执行一次
// 定时任务
TimerTask task = new TimerTask() {
@Override
public void run() {
// 执行数据处理
}
};
timer.schedule(task, 1 * (60 * 1000), period);
急需解决方案!万分感谢帮助!
回答
基于你说的情况,我只是猜想的是,肯定是报错了,不然定时任务不会无缘无故停下,只是呢,这个报错你们没有发现罢了
你们run
方法里应该有一些异常Exception
捕获,但是没有捕获错误,也就是Error
,例如OutOfMemoryError
或者StackOverflowError
等
但是为啥没有报错,我估计是不是你们其他地方写了关于类似Thread.setDefaultUncaughtExceptionHandler
的处理,抓捕了未处理的Throwable
,有可能你们在这里面处理了,也许没有处理,也就是吃掉了,或者异常的日志没有和你们的其他日志放在一起导致你们没有看到
当然都是猜想了哈,毕竟没有你们的代码,也不太好复原,不过我用上诉操作可以模拟出run
突然停止但是可以什么错误也不报的情况,例如模拟一个StackOverflowError
public static void main(String[] args) { Timer timer = new Timer();
// 周期
long period = 10;// 每隔10秒钟执行一次
// 定时任务
TimerTask task = new TimerTask() {
@Override
public void run() {
// 执行数据处理
try{
test();
}catch (RuntimeException e) {
System.out.println("1================" + e.getMessage());
}
}
};
Thread.setDefaultUncaughtExceptionHandler((t, e) -> {
System.out.println("I caught a exception: " + e);
});
timer.schedule(task, 2000, period);
}
// 做一个StackOverflowError
private static String test() {
return test();
}
最后只会打印我Thread.setDefaultUncaughtExceptionHandler
处理的语句,要是我什么都不做,就会出现停止了任务但是啥错也没有的情况
你们也可以查查昨天是否有重启记录,因为往往发生一些Error
导致应用停止,一般的一些自动化集成工具可以再拉起应用的,暂时只能想到这么多了
以上是 Java中Timer自动停止 的全部内容, 来源链接: utcz.com/a/62765.html