Java中Timer自动停止

问题描述

业务需要程序每隔10秒对数据进行一次操作,我使用Timer定时器实现此功能。这个功能在18年就已经上线了,但是昨天发现这个定时器在无人操作的情况下自己停止了。求问问题出现的原因以及解决方案。万分感谢!

具体情况

  1. 昨天没有人动过代码或数据库
  2. 程序没有报错(可能是出现了错误,但是没有输出到日志)
  3. 程序中其它的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处理的语句,要是我什么都不做,就会出现停止了任务但是啥错也没有的情况
Java中Timer自动停止

你们也可以查查昨天是否有重启记录,因为往往发生一些Error导致应用停止,一般的一些自动化集成工具可以再拉起应用的,暂时只能想到这么多了

以上是 Java中Timer自动停止 的全部内容, 来源链接: utcz.com/a/62765.html

回到顶部