Java中Timer自动停止

小胖
  • 70

问题描述

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

具体情况

  1. 昨天没有人动过代码或数据库
  2. 程序没有报错(可能是出现了错误,但是没有输出到日志)
  3. 程序中其它的Timer定时器没有出现问题一直在正常执行

相关代码

Timer timer = new Timer();
// 周期
long period = 10 * 1000;// 每隔10秒钟执行一次
// 定时任务
TimerTask task = new TimerTask() {
    @Override
    public void run() {
        // 执行数据处理
    }
};
timer.schedule(task, 1 * (60 * 1000), period);

急需解决方案!万分感谢帮助!

回复
阅读 1.7k
1 个回答
✓ 已被采纳

基于你说的情况,我只是猜想的是,肯定是报错了,不然定时任务不会无缘无故停下,只是呢,这个报错你们没有发现罢了

你们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处理的语句,要是我什么都不做,就会出现停止了任务但是啥错也没有的情况
image.png

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
你知道吗?

宣传栏