@Schedule是常用的定时任务注解,一般用在需要定时执行的业务逻辑上,多用于单机任务,分布式任务使用的话,需要通过分布式锁保证数据一致性。
如果有多个@Schedule注解定义的定时任务,是并发执行还是串行执行呢?
@Schedule定义的定时任务应该也是有一个线程池,例如4大常见线程池中的ScheduleThreadPool
四大常见线程池:
- SingleThreadPool:单线程的线程池
- FixedThreadPool:固定线程的线程池
- ScheduleThreadPool:定时执行的任务的线程池
- CachedThreadPool:缓存线程数但是线程数量无限大的线程池
那么是并发执行多个定时任务还是只有一个线程串行执行定时任务呢?
如果是串行执行,那么会有严重的问题!定时任务不能按时执行,并且会有阻塞的风险
那么如何让@Schedule
定义的定时任务并发多线程执行呢?
测试
在同一个类中,通过@Schedule
定义多个定时任务,查看多个定时任务是否使用同一个线程执行,并且是否为并行执行
- 示例代码
@Component
public class ScheduleTest {
@Scheduled(cron = "0/30 * * * * ?")
public void task1() {
System.out.println("task1 start");
System.out.println(Thread.currentThread().getId() + " " + Thread.currentThread().getName());
}
@Scheduled(cron = "0/30 * * * * ?")
public void task2() {
System.out.println("task2 start");
System.out.println(Thread.currentThread().