关于java:Spring-Boot-24-新特性全新的Cron表达式处理机制

7次阅读

共计 1440 个字符,预计需要花费 4 分钟才能阅读完成。

说起 cron 表达式大家肯定不生疏,咱们罕用来作为定时工作执行策略规定。在 Spring Boot 框架中 cron 表达式次要配合 @Scheduled 注解在应用程序中应用。在 Spring Boot 2.4(既 Spring 5.3)当前, 引入了 CronExpression
表达式处理器来代替原有的 CronSequenceGenerator。

为什么要代替原有的 CronSequenceGenerator ? 此处理器是基于 java.util.Calendar局限性比拟大,无奈实现last day of month 语义。

  • 例如利用 CronExpression 计算表达式下次执行工夫
  LocalDateTime now = LocalDateTime.now();
  System.out.println("以后运行工夫:" + now);

  // 每小时执行一次
  CronExpression expression1 = CronExpression.parse("0 0 0/1 * * *");
  LocalDateTime nextTime = expression1.next(now);
  System.out.println("每小时执行一次 -> 下次执行工夫:" + nextTime);

   // 每小时第非常执行一次
  CronExpression expression2 = CronExpression.parse("0 10 0/1 * * *");
  LocalDateTime nextTime2 = expression2.next(now);
  System.out.println("每小时第非常执行 -> 下次执行工夫:" + nextTime2);
  • 执行后果
以后运行工夫: 2020-11-14T23:04:46.302739
每小时执行一次 ->   下次执行工夫: 2020-11-15T00:00
每小时第非常执行 -> 下次执行工夫: 2020-11-14T23:10

新增罕用表达式通用宏

对于非开发人员来说 cron 表达式并不容易了解,所以很难在呈现谬误的时候进行修复。比方笔者会把 cron 表达式 在在线网站 模仿运行一下,确认执行过程不便排查问题。

为了进步可读性,Spring Boot 当初反对以下代表罕用表达式的宏。能够应用这些宏而不是六位的表达式,因而:

@Scheduled(cron = "@hourly")。

相当于

@Scheduled(cron = "0 0 * * * *")

其余罕用宏命令

cron 表达式 含意
@yearly 0 0 0 1 1 \* 每年执行一次
@monthly 0 0 0 1 \ \ 每月执行一次
@weekly 0 0 0 \ \ 0 每周执行一次
@daily 或 @annually 0 0 0 \ \ \* 每天执行一次
@hourly 0 0 \ \ \ \ 每小时执行一次

加强原有表达式 最初几天

       每周的第几天
           |
           ∨
 * * * * * *
       ^
       |
    每月的第几天

如上其中的 每月的第几天 每周的第几天 反对 最初几天 (L)的语义
例如:

0 0 0 L * *   每月最初一天的零时

0 0 0 L-3 * *   每月最初第三天的零时  (L-d 格局)

0 0 0 * * 5L    每月最初的星期五零时(dL 格局)0 0 0 * * FRIL  每月最初的星期五零时((星期一星期天的英文缩写)L 格局)

加强原有表达式 工作日

 * * * * * *
       ^
       |
    每月的第几天

如上其中的 每月的第几天 反对 工作日 (W)的语义
例如:

0 0 0 1W * * 每月的第一个工作日零时
0 0 0 LW * * 每月的最初一个工作日零时

加强原有表达式 几周的星期几

       每周的第几天
           |
           ∨
 * * * * * *

如上其中的 每周的第几天 反对 每月第几周的第几天语义
例如

0 0 0 ? * 5#2     每月第二周的星期五零时

0 0 0 ? * MON#1    每月周一的星期一零时

正文完
 0