Welcome to ZaiNaLe Developer Community-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
389 views
in Technique[技术] by (71.8m points)

Java中Timer自动停止

问题描述

业务需要程序每隔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);

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


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Answer

0 votes
by (71.8m points)

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

你们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导致应用停止,一般的一些自动化集成工具可以再拉起应用的,暂时只能想到这么多了


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome to ZaiNaLe Developer Community-Open, Learning and Share
...