阅读量: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; } }