springboot(09)定时任务

Spring Boot中的定时任务是一种可以在预定时间点执行特定任务的功能。这些任务可以在应用程序启动时开始执行,也可以在应用程序运行时按照一定的时间间隔执行。

定时任务可以用在很多场景中,例如定时生成报表、定时发送邮件、定时清理数据等。

在Spring Boot中,定时任务可以通过注解的方式实现。常用的注解包括@Scheduled和@Async。@Scheduled可以用来指定任务的执行时间,而@Async可以用来异步执行任务,提高应用程序的性能。

总之,Spring Boot的定时任务功能非常灵活,可以根据具体的业务需求进行定制和配置,提高应用程序的效率和可靠性。

在项目开发中,经常需要定时任务来帮助我们来做一些内容,比如定时发送短息/站内信、数据汇总统计、业务监控等。

一、方式1

1、启动类开启定时任务

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

2、创建定时任务实现类

以下是使用@Scheduled注解来实现定时任务的示例代码:

@Component
public class MyTask {
    
    
    private static final SimpleDateFormat f = new SimpleDateFormat("HH:mm:ss");

    @Scheduled(fixedDelay = 5000) // 每隔5秒钟执行一次任务
    public void doTask() {
    
    
        // 执行任务的代码
        System.out.println("Scheduled-fixedRate 方式:开始定时任务,现在时间:"+f.format(new Date()));
    }

}

使用@Async注解来实现异步执行任务的示例代码:

@Component
public class MyTask {
    
    

    @Async
    public void doTask() {
    
    
        // 执行任务的代码
    }

}

3、测试:

运行工程控制台打印

Scheduled-fixedRate 方式:开始定时任务,现在时间:14:12:37
Scheduled-fixedRate 方式:开始定时任务,现在时间:14:12:42
Scheduled-fixedRate 方式:开始定时任务,现在时间:14:12:47
Scheduled-fixedRate 方式:开始定时任务,现在时间:14:12:52
Scheduled-fixedRate 方式:开始定时任务,现在时间:14:12:57
Scheduled-fixedRate 方式:开始定时任务,现在时间:14:13:02

4、@Scheduled参数说明

在上面的例子中,使用了@Scheduled(fixedRate = 5000)注解来定义每5秒执行的任务,对于@Scheduled的使用可以总结如下几种方式:
fixedRate 说明

  • @Scheduled(fixedRate = 5000) 上一次开始执行时间点之后5秒在执行
  • @Scheduled(fixedDelay = 5000) 上一次执行完毕时间点之后5秒执行
  • @Scheduled(initialDelay = 1000 ,fixedRate = 5000)第一次延迟1秒后执行(程序启动后延迟1秒),之后按fixedRate的规则每5秒执行一次

二、方式2

在Spring Boot中,可以使用@Scheduled注解来指定任务的执行时间,也可以使用cron表达式来指定任务的执行时间。以下是使用cron方式来实现定时任务的示例代码:

1、定时任务实现方法

    @Scheduled(cron = "*/5 * * * * ?")
    public void processCron() {
    
    
        System.out.println("Scheduled-cron 方式:开始定时任务,现在时间:"+f.format(new Date()));
    }

cron表达式是一种用来指定定时任务执行时间的格式,其格式为:

秒 分 时 日 月 星期

其中,表示秒数,取值范围为0-59;表示分钟数,取值范围为0-59;表示小时数,取值范围为0-23;表示日数,取值范围为1-31;表示月份,取值范围为1-12;星期表示星期几,取值范围为0-7,其中0和7都表示星期日。

cron表达式可以使用以下特殊符号:

  • ``:表示所有可能的值;
  • /:表示每隔一定时间执行一次任务;
  • ``:表示一个范围内的值;
  • ,:表示多个值。

例如,0 0/5 * * * ?表示每隔5分钟执行一次任务,0 0 12 * * ?表示每天中午12点执行一次任务,0 0 12 * * ? *表示每天中午12点执行一次任务,并且不考虑星期几的影响。

需要注意的是,cron表达式中的时间是按照服务器所在的时区来计算的,因此在使用cron表达式时需要注意时区的设置。

2、参数说明

2.1位数说明

一个cron表达式有至少6位(也可能7位)数字组成(每个数字称作元素),用空格分隔的时间元素。

按顺序依次为:

  1. 秒(取值范围: 0~59,不能超过59,若取值为60的话,也会提示表达式不合格)
  2. 分钟(0~59)
  3. 小时(0~23)
  4. 天(1~31)
  5. 月(0~11)
  6. 星期(1~7 1=SUN 或 SUN,MON,TUE,WED,THU,FRI,SAT)
  7. 年份(1970-2199)
    请添加图片描述
    其中每个元素可以是 一个值(如6) 或,
    一个连续区间(例:9-12) 或, #意思: 9点 ~ 12点
    一个间隔时间(8-18/4)(/表示每隔4小时) 或,
    一个列表(1,3,5) 或,
    通配符 (*)
2.2 cron表达式规则

每一个域都使用数字,但还可以出现如下特殊字符,它们的含义是:
请添加图片描述
(1):表示匹配该域的任意值。假如在Minutes域使用, 即表示每分钟都会触发事件。

(2)?:只能用在DayofMonth和DayofWeek两个域。它也匹配域的任意值,但实际不会。因为DayofMonth和DayofWeek会相互影响。例如想在每月的20日触发调度,不管20日到底是星期几,则只能使用如下写法: 13 13 15 20 * ?, 其中最后一位只能用?,而不能使用*,如果使用*表示不管星期几都会触发,实际上并不是这样。

(3)-:表示范围。例如在Minutes域使用5-20,表示从5分到20分钟每分钟触发一次

(4)/:表示起始时间开始触发,然后每隔固定时间触发一次。例如在Minutes域使用5/20,则意味着5分钟触发一次,而25,45等分别触发一次.

(5),:表示列出枚举值。例如:在Minutes域使用5,20,则意味着在5和20分每分钟触发一次。

(6)L:表示最后,只能出现在DayofWeek和DayofMonth域。如果在DayofWeek域使用5L,意味着在最后的一个星期四触发。

(7)W:表示有效工作日(周一到周五),只能出现在DayofMonth域,系统将在离指定日期的最近的有效工作日触发事件。例如:在 DayofMonth使用5W,如果5日是星期六,则将在最近的工作日:星期五,即4日触发。如果5日是星期天,则在6日(周一)触发;如果5日在星期一到星期五中的一天,则就在5日触发。另外一点,W的最近寻找不会跨过月份 。

(8)LW:这两个字符可以连用,表示在某个月最后一个工作日,即最后一个星期五。

(9)#:用于确定每个月第几个星期几,只能出现在DayofMonth域。例如在4#2,表示某月的第二个星期三

3、熟悉规则举例:

例子如下:
秒  分  时  天  月  星期  年
 
* * * * * ? *       解释: 每秒执行一次(所有元素都可以是任意值,那就从秒元素开始,以每秒为单位触发);如果前几位用数值定死了,那就以本位元素为单位来进行触发
 
0 * * * * ?         解释: 每1分钟触发一次(秒元素定死了,那就从分钟元素开始,*可以为分钟元素取值范围内的任意值,那就以每分钟为单位触发)
0/40 * * * * ?     解释: 增量后的值遇到当前元素取值范围最大值时,会被置为取值范围最小值   例: 0:00:000:00:400:01:000:01:400:02:00......
 
0 0 * * * ?         解释: 每1小时触发一次(秒元素和分钟元素都定死了,那就从小时元素开始,以每小时为单位触发)
0 0 0 * * ?         解释: 每天凌晨00000运行一次(秒、分、时元素都定死了,那就从日期元素开始,以每天为单位触发)
0 0 0 1 * ?         解释: 每月1号凌晨触发
 
0 0 10,14,16 * * ?  解释:小时元素用了一个列表,表示每天上午10点,下午2点,4点执行
 
0 0/30 9-17 * * ?   解释:分钟元素用了一个增量,小时元素用了一个连续区间,表示早9点到下午5点每半小时执行一次(9:009:301000......)
 
0 0 12 ? * WED      解释:小时元素用了一个数值,星期元素用了一个数值,表示每个星期三中午12"0 0 12 * * ?"      解释:小时元素用了一个数值,表示每天中午12点触发 
 
"0 15 10 ? * *"     解释:分钟元素用了一个数值,小时元素用了一个数值,表示每天上午10:15触发 
 
"0 15 10 * * ?"     解释:每天上午10:15触发 
 
"0 15 10 * * ? *"   解释: 每天上午10:15触发 
 
"0 15 10 * * ? 2005"  解释:分钟、小时、年三个元素都用了一个数值 ,表示:2005年的每天上午10:15触发 
 
"0 * 14 * * ?"      解释: 在每天下午2点到下午2:59期间的每1分钟触发 (分钟元素取值范围为0-59)例: 14:00:0014:01:0014:02:00 ...... 14:59:00
 
"0 0/5 14 * * ?"    解释: 在每天下午2点到下午2:55(因为分钟元素只能取值到59,所以不会到3:00,只能到2:55)期间的每5分钟触发 例:14:00:0014:05:0014:10:00......14:55:00
 
"0 0/5 14,18 * * ?"  解释: 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发 
 
"0 0-5 14 * * ?"      解释: 在每天下午2点到下午2:05期间的每1分钟触发 
 
"0 10,44 14 ? 3 WED"  解释:分钟元素用了一个列表,小时、月、星期用了一个数值,表示每年三月的每个星期三的下午2:102:44触发 
 
"0 15 10 ? * MON-FRI" 解释:每月的每周的周一至周五每天的上午10:15触发 
 
"0 15 10 15 * ?"      解释: 每月15日上午10:15触发 (日和星期用一个数值和?指定,避免两者的日期冲突)
 
"0 15 10 L * ?"       解释: 每月最后一天的上午10:15触发 (L 用在了日期的位置上)
 
"0 15 10 ? * 6L"      解释: 每月的最后一个星期五上午10:15触发 (L用在星期元素上,6表示星期五)
 
"0 15 10 ? * 6L 2002-2005"  解释:2002年至2005年的每月的最后一个星期五上午10:15触发 
 
"0 15 10 ? * 6#3"    解释: 每月的第三个星期五上午10:15触发
 
建议: 为了CRON表达式准确无误,可以用在线工具进行验证

猜你喜欢

转载自blog.csdn.net/Bilal_0/article/details/129947830
今日推荐