spring的@Scheduled定时任务,同一时间段的定时任务只会执行一个,其余的会被阻塞,@Scheduled注解定时任务并发执行解决办法,即多线程运行定时任务
原文:https://blog.csdn.net/qq_35937303/article/details/88851064
现有两个定时任务
@Component("aa") public class aa { @Scheduled(cron = "0 44 17 * * ?") public void bb() { try { System.out.println("aa执行时间:" + new Date()); Thread.sleep(65000); System.out.println("aa完成时间:" + new Date()); } catch (Exception e) { e.printStackTrace(); } } }
@Component("bb") public class bb { @Scheduled(cron = "0 55 17 * * ?") public void aa() { try { System.out.println("bb执行时间:" + new Date()); Thread.sleep(10000); System.out.println("bb完成时间:" + new Date()); } catch (Exception e) { e.printStackTrace(); } } }
默认的在启动项加入@EnableScheduling注解就可以运行了
最终,执行的结果令人大跌眼镜。
aa的任务由于执行时间需要65秒,超过了bb任务执行的时间,结果bb任务执行的时间被阻塞掉,延迟了5秒执行。
解决方法是在启动项类中加入如下配置即可
@Bean public TaskScheduler taskScheduler() { ThreadPoolTaskScheduler taskScheduler = new ThreadPoolTaskScheduler(); taskScheduler.setPoolSize(50); return taskScheduler; }
如果是xml
<!-- 注解式 -->
<task:annotation-driven executor="myExecutor" scheduler="myScheduler"/>
<task:executor id="myExecutor" pool-size="5"/>
<task:scheduler id="myScheduler" pool-size="10"/>
看完打开支付宝扫一扫领个红包吧!