@Scheduled注解定时任务未按时执行问题记录

avatar
作者
筋斗云
阅读量:0

文章目录

问题

在一个项目中多处使用了@Scheduled注解,有些任务是1分钟执行一次,有些任务是每天凌晨0点执行一次。但是发现本该在凌晨0点执行的任务在0点并没有执行,而是在凌晨1点多才执行,而且每次执行的时间还不一样。

原因

经排查原因是因为每分钟执行一次的任务,在1分钟内执行不完,且@Scheduled注解底层虽然是使用线程池,但是线程池中默认只有一个线程!在0点的时候前面还有很多1分钟执行一次的任务没执行完,导致在0点执行的任务阻塞,直到前面阻塞的任务都执行完,1点多才执行0点的任务。@Scheduled相关源码:

在这里插入图片描述

解决方案

可以在SpringBoot ymal文件中配置。也可以向下边一样注入配置类即可

@Configuration public class SchedulerConfig {      @Bean     public ThreadPoolTaskScheduler taskScheduler() {         ThreadPoolTaskScheduler taskScheduler = new ThreadPoolTaskScheduler();         taskScheduler.setThreadNamePrefix("MyTask-Thread-");         taskScheduler.setPoolSize(20);         taskScheduler.setWaitForTasksToCompleteOnShutdown(true);         taskScheduler.initialize();         return taskScheduler;     } } 

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!