提及 cron 表达式你们必定不陌生,咱们经常使用来做为定时任务执行策略规则。 在 Spring Boot 框架中 cron 表达式主要配合 @Scheduled 注解在应用程序中使用。 在 Spring Boot 2.4 (既 Spring 5.3)之后,引入了 CronExpression
表达式处理器来替代原有的 CronSequenceGenerator。java
为何要替代原有的 CronSequenceGenerator ? 此处理器是基于 java.util.Calendar
局限性比较大,没法完成last day of month
语义。express
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")。
至关于url
@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) 的语义
例如:spa
0 0 0 L * * 每个月最后一天的零时 0 0 0 L-3 * * 每个月最后第三天的零时 (L-d 格式) 0 0 0 * * 5L 每个月最后的星期五零时 (dL 格式) 0 0 0 * * FRIL 每个月最后的星期五零时 ( (星期一星期天的英文缩写)L 格式)
* * * * * * ^ | 每个月的第几天
如上其中的 每个月的第几天
支持 工做日 (W)的语义
例如:code
0 0 0 1W * * 每个月的第一个工做日零时 0 0 0 LW * * 每个月的最后一个工做日零时
每周的第几天 | ∨ * * * * * *
如上其中的 每周的第几天
支持 每个月第几周的第几天语义
例如开发
0 0 0 ? * 5#2 每个月第二周的星期五零时 0 0 0 ? * MON#1 每个月周一的星期一零时