现象
在一个类内,写了两个定时任务,发现它们竟然是串行执行的。
于是想到, @Scheduled 该不会是单线程执行折吧?
于是找了一下,发现还真的是。。。
可参考: https://blog.csdn.net/Mr_EvanChen/article/details/103408290
解决方案
1、ScheduledTaskRegistrar 有一个 setScheduler() 方法,
可以通过这个方法,设置它的执行线程池。。。改为多核心线程数的线程池。
@Configuration
public class ScheduleConfig implements SchedulingConfigurer {
@Override
public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
taskRegistrar.setScheduler(Executors.newScheduledThreadPool(50));
}
@Bean
public Executor taskExecutor() {
ThreadPoolTaskScheduler threadPoolTaskScheduler = new ThreadPoolTaskScheduler();
threadPoolTaskScheduler.setPoolSize(10);
threadPoolTaskScheduler.setThreadNamePrefix("My-Schedule: ");
threadPoolTaskScheduler.initialize();
return threadPoolTaskScheduler;
}
}
2、在原来的模块,加 上这个配置,它就变成多线程执行了。
注意
标签:Scheduled,单线程,任务,线程,定时,多线程,threadPoolTaskScheduler From: https://www.cnblogs.com/aaacarrot/p/17805903.html这种方法,每次定时任务启动的时候,都会创建一个单独的线程来处理。也就是说同一个定时任务也会启动多个线程处理。
例如:任务1和任务2一起处理,但是线程1卡死了,任务2是可以正常执行的。且下个周期,任务1还是会正常执行,不会因为上一次卡死了,影响任务1。
但是任务1中的卡死线程越来越多,会导致50个线程池占满,还是会影响到定时任务。
所以,如果发现有定时任务会长时间卡住,还是赶紧解决掉才行呀~