SpringBoot ThreadPoolTaskScheduler 定时任务 多线程执行 demo

1. pom文件

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.3.3.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <groupId>com.demo</groupId> <artifactId>springboot-scheduler-demo</artifactId> <version>1.0.0</version> <properties> <lombok.version>1.18.12</lombok.version> </properties> <dependencies> <!--web 模块--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- lombok--> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> <scope>provided</scope> <version>${lombok.version}</version> </dependency> </dependencies> </project>

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


__EOF__

本文作者stonechen
本文链接https://www.cnblogs.com/stonechen/p/14258539.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   没事摸摸小肚子  阅读(1673)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示