Spring Task的使用

一、什么是Spring Task

Spring Task 是 Spring 框架的一个组件,它为任务调度提供了支持,使得开发者能够创建后台任务或定期执行的任务。通过 Spring Task,您可以方便地在 Java 应用程序中实现定时任务,比如每天凌晨进行数据同步、每小时执行一次清理操作等。

二、开启Spring Task

启动类添加**@EnableScheduling** 注解,以开启基于注解的任务调度器。默认情况下,系统会自动启动一个线程,调度执行项目中定义的所有定时任务

三、同步定时任务 @Scheduled 定时任务

**在需要定时执行的方法上添加@Scheduled注解即可。**定时执行的方法不能有参数,并且一般没有返回值,即使有返回值也没什么用;并且要把定时方法所在的类放入IOC容器

3.1**@Scheduled注解的使用**

1.fixedDelay:上次结束到下次开始之间的时间间隔

java 复制代码
@Scheduled(fixedDelay = 4000) 

2.fixedRate:上一次开始执行时间和下次开始时间间隔10s

java 复制代码
@Scheduled(fixedRate = 10000) 

3. initialDelay:第一次延迟多长时间后再执行。

java 复制代码
@Scheduled(initialDelay=1000, fixedRate=5000) 
//第一次延迟1秒后执行,之后按fixedRate的规则每5秒执行一次

四、异步定时任务(@Async)

4.1开启异步支持

要在 Spring Boot 应用中启用异步方法调用,需在启动类上添加 @EnableAsync 注解。

4.2定义异步方法

在服务类中定义一个方法,并使用 @Async 注解标记它以实现异步执行;

五、自定义线程池

java 复制代码
@Component
public class ExecutorConfig {
    //定义核心线程数
    public static final  int CORE_POOL_SIZE = 10;
    // 最大线程数
    public static final  int MAX_POOL_SIZE = 20;
    // 任务队列容量大小
    public static final  int QUEUE_MAX_COUNT = 100;

    @Bean("asyncScheduledPool")
    //放进IOC容器并起名称
    public Executor asyncScheduledPool(){
        //自定义线程池
        ThreadPoolTaskExecutor threadPoolExecutor = new ThreadPoolTaskExecutor();
        //设置核心线程数
        threadPoolExecutor.setCorePoolSize(CORE_POOL_SIZE);
        //设置最大线程数 : 长工 +  临时工
        threadPoolExecutor.setMaxPoolSize(MAX_POOL_SIZE);
        //设置任务队列容量大小
        threadPoolExecutor.setQueueCapacity(QUEUE_MAX_COUNT);
        //设置线程的名称前缀
        threadPoolExecutor.setThreadNamePrefix("myTask-");
        //设置拒绝策略
        threadPoolExecutor.setRejectedExecutionHandler(new ThreadPoolExecutor.AbortPolicy());
        return  threadPoolExecutor;
    }

}

请注意,阿里并不推荐使用JDK自带的线程池,因为他有一些弊端,不是不让使用,而是使用的时候我们最好能定义一些确切参数

为什么阿里不推荐使用JDK自带线程池

如图:我们可以看到核心线程数,最大线程数,以及最大空闲等待时间,除了图上所示的还有队列,他们设置的值都是Interger.MAX.VALUE,这个值的最大值能达到21亿,也就是说,如果不加管控,就可能一直创建线程达到21亿个,如果内存不足一定会引发OOM(内存溢出)问题

他的缺点有:

1、资源耗尽的风险

2、拒绝策略不明确

3、线程池参数优化

4、监控和调试难度

总结起来,阿里巴巴之所以推荐使用 ThreadPoolExecutor 手动创建线程池,是为了增强系统稳定性,降低资源耗损风险,并提升开发者对线程池行为的控制能力。

六、cron表达式(可以去网上查找相应的在线工具)

相关推荐
2301_8153577010 小时前
parameterType和@Param注解的区别
java·开发语言·数据库
We....10 小时前
Java 分布式缓存实现:结合 RMI 与本地文件缓存
java·分布式·缓存
2401_8454174510 小时前
set和map
java·开发语言
所愿ღ10 小时前
JavaWeb-Servlet总结及JSP
java·笔记·servlet
杨杨杨大侠11 小时前
Atlas Mapper 教程系列 (4/10):高级映射技巧与类型转换
java·开源·github
杨杨杨大侠11 小时前
Atlas Mapper 教程系列 (3/10):核心注解详解与基础映射
java·开源·github
LaoZhangAI11 小时前
Google Gemini AI图片编辑完全指南:50+中英对照提示词与批量处理教程(2025年9月)
前端·后端
小枫编程11 小时前
Spring Boot 调度任务在分布式环境下的坑:任务重复执行与一致性保证
spring boot·分布式·后端
用户114818678948411 小时前
从零搭建 Vue3 + Nest.js 实时通信项目:4 种方案(短轮询 / 长轮询 / SSE/WebSocket)
前端·后端
LaoZhangAI11 小时前
Google Gemini Nano与Banana AI完整部署指南:2025年轻量级AI解决方案
前端·后端