@Scheduled异步执行-自定义线程池

Springboot中使用@Scheduled开启的定时任务,默认使用的是单线程的线程池

public class ContextLifecycleScheduledTaskRegistrar extends ScheduledTaskRegistrar implements SmartInitializingSingleton {

	@Override
	public void afterPropertiesSet() {
		// no-op
	}

	@Override
	public void afterSingletonsInstantiated() {
		scheduleTasks();
	}

}

在这里插入图片描述

这就会导致多个任务时,可能不会按预期的时间执行

举个例子,这里我开启了两个定时任务

task1每3s执行一次,task2每1s执行一次

@Component
@Slf4j
public class Task {
    @Scheduled(fixedRate = 3000)
    public void task1() {
        try {
            TimeUnit.SECONDS.sleep(3);
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }
        log.info("task1:{}", LocalDateTime.now());
    }
    @Scheduled(fixedRate = 1000)
    public void task2() {
        log.info("task2:{}", LocalDateTime.now());
    }
}

打印日志如下

可以看到task1执行阻塞3s后,task2才开始执行,并且一次性执行了3次

这显然是不符合预期的

2024-08-13 11:35:09.330  INFO 32804 --- [   scheduling-1] com.yimin.demo.config.Task               : task1:2024-08-13T11:35:09.330
2024-08-13 11:35:09.330  INFO 32804 --- [   scheduling-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:35:09.330
2024-08-13 11:35:09.330  INFO 32804 --- [   scheduling-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:35:09.330
2024-08-13 11:35:09.330  INFO 32804 --- [   scheduling-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:35:09.330
2024-08-13 11:35:12.339  INFO 32804 --- [   scheduling-1] com.yimin.demo.config.Task               : task1:2024-08-13T11:35:12.339
2024-08-13 11:35:12.339  INFO 32804 --- [   scheduling-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:35:12.339
2024-08-13 11:35:12.339  INFO 32804 --- [   scheduling-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:35:12.339
2024-08-13 11:35:12.339  INFO 32804 --- [   scheduling-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:35:12.339

问题就在于线程池中只有一个线程

要解决这个问题,我们只需要自定义线程池中的线程数即可

@Configuration
public class ScheduleConfig implements SchedulingConfigurer {
    @Override
    public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
        ThreadPoolTaskScheduler threadPoolTaskScheduler = new ThreadPoolTaskScheduler();
        threadPoolTaskScheduler.setPoolSize(2);
        threadPoolTaskScheduler.initialize(); // optional
        taskRegistrar.setTaskScheduler(threadPoolTaskScheduler);
    }
}

配置完再运行

task1每3s执行一次,task2每1s执行一次

两个任务使用的是不同线程,彼此互不干扰,结果符合预期

2024-08-13 11:45:21.693  INFO 20524 --- [TaskScheduler-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:45:21.693
2024-08-13 11:45:22.694  INFO 20524 --- [TaskScheduler-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:45:22.694
2024-08-13 11:45:23.679  INFO 20524 --- [TaskScheduler-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:45:23.679
2024-08-13 11:45:23.679  INFO 20524 --- [TaskScheduler-2] com.yimin.demo.config.Task               : task1:2024-08-13T11:45:23.679
2024-08-13 11:45:24.679  INFO 20524 --- [TaskScheduler-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:45:24.679
2024-08-13 11:45:25.693  INFO 20524 --- [TaskScheduler-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:45:25.693
2024-08-13 11:45:26.689  INFO 20524 --- [TaskScheduler-1] com.yimin.demo.config.Task               : task2:2024-08-13T11:45:26.689
2024-08-13 11:45:26.689  INFO 20524 --- [TaskScheduler-2] com.yimin.demo.config.Task               : task1:2024-08-13T11:45:26.689
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值