SpringBoot2使用 ThreadPoolTaskScheduler 定时任务 多线程执行

SpringBoot2使用 ThreadPoolTaskScheduler 定时任务 多线程执行,第1张

1. pom文件
 

4.0.0 org.springframework.boot spring-boot-starter-parent 2.3.3.RELEASE com.demo springboot-scheduler-demo 1.0.0 1.18.12 org.springframework.boot spring-boot-starter-web org.projectlombok lombok true provided ${lombok.version}

2. SchedulerApplication.java

启动类

 

@SpringBootApplication @EnableScheduling public class SchedulerApplication { public static void main(String[] args) { SpringApplication.run(SchedulerApplication.class, args); } }

添加@EnableScheduling注解,启用定时任务。

3. SchedulerConfig.java

定时任务配置类

 

@Configuration @EnableAsync public class SchedulerConfig { @Bean public Executor taskExecutor() { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); // 设置线程名称前缀,默认为方法名(此处为taskExecutor) //executor.setThreadNamePrefix("task-"); // 核心线程数 executor.setCorePoolSize(10); // 最大线程数 executor.setMaxPoolSize(100); // 等待队列容量 executor.setQueueCapacity(50); // 空闲线程存活时间(单位:s) executor.setKeepAliveSeconds(300); executor.initialize(); return executor; }

添加@EnableAsync注解,启用多线程。

线程池不同情况说明:

  • 若线程数 < corePoolSize,即使线程池中的线程都处于空闲状态,也要创建新的线程来处理被添加的任务。
  • 若线程数 = corePoolSize,但是缓冲队列workQueue未满,那么任务被放入缓冲队列。
  • 若线程数 > corePoolSize,缓冲队列workQueue满,并且线程数 < maxPoolSize,创建新的线程来处理被添加的任务。
  • 若线程数 > corePoolSize,缓冲队列workQueue满,并且线程数 = maxPoolSize,那么通过handler所指定的策略来处理此任务。
    处理任务的优先级为:核心线程corePoolSize、任务队列workQueue、最大线程maximumPoolSize。如果三者都满了,使用handler处理被拒绝的任务。
  • 若线程数 > corePoolSize时,如果某线程空闲时间超过keepAliveTime,线程将被终止。
4. TestScheduler.java

具体定时任务执行类

 

@Slf4j @Component @Async public class TestScheduler { @Scheduled(cron = "0/3 * * * * *") public void test() { log.info("执行定时任务test1"); } @Scheduled(cron = "0/6 * * * * *") public void test2() { log.info("执行定时任务test2"); } }

在类上添加@Async注解,类中的所有方法都会使用多线程执行任务。
类上不添加,方法上添加@Async,仅添加过@Async的方法会使用多线程执行任务。

5. cron表达式

@Scheduled cron表达式

// Update 2021年1月12日 增加Demo
Demo

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/787637.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-05
下一篇 2022-05-05

发表评论

登录后才能评论

评论列表(0条)

保存