SpringBoot整合定时任务

一、 Scheduled原理

JUC 包中的 Executor 架构带来了线程的创建与执行的分离。Executor 的继承者ExecutorService 下面衍生出了两个重要的实现类,他们分别是

1、ThreadPoolExecutor 线程池

2、ScheduledThreadPoolExecutor 支持周期性任务的线程池

通过 ThreadPoolExecutor 可以实现各式各样的自定义线程池,而 ScheduledThreadPoolExecutor 类则在自定义线程池的基础上增加了周期性执行任务的功能

二、导入依赖

springboot3之后自带定时任务器,所以只需要引用springboot启动器就可以

java 复制代码
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>3.0.5</version>
</parent>

三、编写定时任务

定时任务所在的类需要是spring的组件,所以在定时任务类上需要加上@Component注解,并且在定时任务方法上加上@Scheduled注解,声明这是一个定时任务。(这里需要注意的是@Scheduled注解里面的cron表达式,后面会详细介绍)

java 复制代码
@Component
public class MySchduled {
    private int count = 0;

    @Scheduled(cron = "0/3 * * * * ? ")
    public void print(){
        System.out.println("hello:" + count++);
    }
}

四、Cron表达式

Cron表达式是一种用于指定定时任务执行时间的字符串,它由六个或七个字段组成,分别表示秒分时日期月份星期年份(可选)。每个字段可以是一个具体的值、一个范围、一个递增步长,或者使用特殊字符。12

  • 星号(*):在某个字段中使用时,表示该字段可以取该字段的所有可能值。例如,在分钟字段中使用 * 表示每分钟。
  • 问号(?):只在日期和星期字段中使用,通常作为无意义的值,相当于占位符。
  • 减号(-):表示一个范围,例如在小时字段中使用"10-12"表示从10点到12点,即10、11、12点。
  • 逗号(,):表示一个列表值,例如在星期字段中使用"MON,WED,FRI"表示星期一、星期三和星期五。
  • 斜杠(/):表示一个等步长序列,例如在分钟字段中使用0/15表示从0秒开始,每隔15秒触发一次。
  • L:只在日期和星期字段中使用,代表"Last"的意思,在日期字段中表示这个月份的最后一天,在星期字段中表示星期六。
  • W:只能出现在日期字段里,是对前导日期的修饰,表示离该日期最近的工作日。

例如,上面我们使用的(0/3 * * * * ?)的意思就是每隔3秒执行一次

网上有很多cron表达式在线生成器,可以在线生成,使用起来也比较方便

五、启动

启动定时任务扫描是非常重要的一步,没启动的话定时任务不会执行,启动定时任务需要在启动类或者配置类上添加@EnableScheduling注解,表示启动定时任务扫描

java 复制代码
@SpringBootApplication
@MapperScan("com.zxc.mapper")
@EnableScheduling
@EnableAspectJAutoProxy
public class AuthApplication {
    public static void main(String[] args) {
        SpringApplication.run(AuthApplication.class,args);
    }
}
相关推荐
小曲程序1 分钟前
vue3 封装request请求
java·前端·typescript·vue
陈王卜19 分钟前
django+boostrap实现发布博客权限控制
java·前端·django
小码的头发丝、19 分钟前
Spring Boot 注解
java·spring boot
午觉千万别睡过22 分钟前
RuoYI分页不准确问题解决
spring boot
java亮小白199724 分钟前
Spring循环依赖如何解决的?
java·后端·spring
飞滕人生TYF31 分钟前
java Queue 详解
java·队列
2301_8112743141 分钟前
大数据基于Spring Boot的化妆品推荐系统的设计与实现
大数据·spring boot·后端
武子康1 小时前
大数据-230 离线数仓 - ODS层的构建 Hive处理 UDF 与 SerDe 处理 与 当前总结
java·大数据·数据仓库·hive·hadoop·sql·hdfs
武子康1 小时前
大数据-231 离线数仓 - DWS 层、ADS 层的创建 Hive 执行脚本
java·大数据·数据仓库·hive·hadoop·mysql
苏-言1 小时前
Spring IOC实战指南:从零到一的构建过程
java·数据库·spring