基于你说的情况,我只是猜想的是,肯定是报错了,不然定时任务不会无缘无故停下,只是呢,这个报错你们没有发现罢了
你们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
导致应用停止,一般的一些自动化集成工具可以再拉起应用的,暂时只能想到这么多了
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…