文章目录
- 问题
- 原因
- 解决方案
问题
在一个项目中多处使用了@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;
}
}