@Scheduled定时任务没有按时执行的问题与解决方法

问题:

之前生产上用@Scheduled注解写了一个springboot定时任务,5分钟执行一次,如下:

@Scheduled(cron = "0 0/5 * * * ?")
public void MyTimerJobSchedule() throws Exception {
  //省略具体业务逻辑
  System.out.println("五分钟执行一次");
}

结果过了几天,领导通知说有问题了,一查日志,发现是这个定时任务的问题。

本来应该是5分钟跑一次的,结果日志中发现,每天0点-3点时还比较正常,3-10点时居然没有执行;一直到10-11点之间才继续跑起来。

 

原因:

通过百度,发现可能是定时任务单线程模式导致任务阻塞的问题;

继续分析日志,发现该定时任务的线程号是[Scheduling-1],除了执行自身的任务外,还打印了其它定时任务的输出语句;

每天3点前,[Scheduling-1]线程在执行本人写的5分钟一次的定时任务,3点后,[Scheduling-1]线程会执行另一个比较耗时的定时任务,直到10点后,[Scheduling-1]线程才重新执行5分钟一次的定时任务。

 

看来,确实是由于@Scheduled定时任务默认使用单线程模式导致的问题;一旦有一个定时任务比较耗时,就会影响到其它定时任务按时执行。

 

解决方法:

在定时任务上增加@Async注解,并在启动类上增加@EnableAsync注解,使用多线程模式执行定时任务。

 

备注:

参考网址:https://blog.youkuaiyun.com/LYM0721/article/details/89499588

参考网址中有第二种解决方法,但是已说明不太好用,因此只用第一种解决方法就够了。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

追逐梦想永不停

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值