解决spring定时器定时任务到时间未执行问题

 

spring定时器定时任务到时间未执行

应用场景

一个定时器类中有n个定时任务,有每30秒执行一次的还有每1分钟执行一次的,出现问题的定时任务是0点整时执行的定时任务到了0点没有执行。

原因分析

spring定时器任务scheduled-tasks默认配置是单线程串行执行的,当某个定时任务出现阻塞,或者执行时间过长,则线程就会被占用,其他定时任务排队执行,导致后面的定时任务未能准时执行。

解决方式

开启多线程定时任务执行

/**
* 多线程执行定时任务
*/
@Configurable
public class ScheduleConfig implements SchedulingConfigurer {
  private static final int FIVE = 5;
  @Override
  public void configureTasks(ScheduledTaskRegistrar scheduledTaskRegistrar) {
      scheduledTaskRegistrar.setScheduler(Executors.newScheduledThreadPool(FIVE));
  }
}

 

解决修改系统时间后Spring 定时任务不执行

问题描述

Spring 定时任务不执行

事情起因是这样的,我们有一个spring定时任务,每隔半小时要执行一次。

起因

由于种种原因,昨晚上这台服务器被关机了,今早【重启服务器】和【启动定时任务服务】。

机器重启后,发现服务器机器系统时间和实际北京时间不一致,相差10个小时。

于是乎,我使用date -s 10:35:35 设置和北京时间保持一致。

错误

本以为这样,时间已经一致了,定时任务应该能正常执行了!

等了好几个小时,定时任务依然没有执行。

于是查看系统日志,系统日志一切正常,只是没有定时任务执行的log日志。

解决问题

奇了个怪,服务正常启动,但定时任务没有执行。

然而昨天还在跑的服务,就因为一次关机,就over了?

不可能,于是关掉应用服务再次重启。

定时任务执行成功了,于是得出结论: 服务器系统时间改变后,Spring 定时任务将失效。

服务器系统时间改变后,Spring 定时任务将失效,解决方法就是:重启应用服务。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程宝库

工作中是否遇到这样的场景?1、需要异步线程执行,而且需要获取到线程执行返回的结果。2、如果执行过程异常,可以按照自定义方式消费异常信息。如果只是单纯的使用Callable可以实现,本文提供更加 ...