@Scheduled并发执行多个任务配置

@Scheduled并发执行多个任务配置


项目中定义多个定时任务

@Component
@Slf4j
public class DynamicTask {

    @Autowired
    private DynamicTestMapper dynamicTestMapper;

    @Scheduled(cron = "0 */1 * * * ?")
    public void test() {
        log.info("查询系统列表test");
        List<Map<String, Object>> mapList = dynamicTestMapper.querySystemList();

        try {
            Thread.sleep(5000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        log.info("test数据大小:" + mapList.size());
    }

    @Scheduled(cron = "0 */1 * * * ?")
    public void test1() {
        log.info("查询系统列表test1");
        List<Map<String, Object>> mapList = dynamicTestMapper.querySystemList();
        log.info("test1数据大小:" + mapList.size());
    }
}

从运行结果可以看到,两个定时任务是一个线程在执行,串行的。运行结果如下:
在这里插入图片描述
查看源码发现在项目启动的时候,ScheduledAnnotationBeanPostProcessor会执行finishRegistration方法,在spring容器中查找TaskScheduler和ScheduledExecutorService(java原生的)的bean,因为项目中未注入bean,这里获取的都是null值。
在这里插入图片描述
然后会执行ScheduledTaskRegistrar的scheduleTasks方法注册所有定时任务,在此方法内创建了一个newSingleThreadScheduledExecutor单线程的线程池,作为TaskScheduler的线程池。因此在执行定时任务的时候只有一个线程在串行化的执行所有任务。
在这里插入图片描述
因此,我们只需要自定义一个TaskScheduler,设置线程数即可。这里使用ThreadPoolTaskScheduler ,ThreadPoolTaskScheduler 的默认线程数也是1。

@Configuration
public class ScheduleConfig {

    private static final int CORE_POOL_SIZE = Runtime.getRuntime().availableProcessors() * 2 + 1;

    @Bean
    public ThreadPoolTaskScheduler threadPoolTaskScheduler() {
        ThreadPoolTaskScheduler threadPoolTaskScheduler = new ThreadPoolTaskScheduler();
        threadPoolTaskScheduler.setPoolSize(CORE_POOL_SIZE);
        return threadPoolTaskScheduler;
    }
}

在这里插入图片描述
重新启动程序,可以看到自定义的TaskScheduler已经注入,且线程数为13。
在这里插入图片描述
运行结果:
在这里插入图片描述

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值