定时任务框架:quartz、elastic-job和xxl-job的分析对比

参考:https://blog.csdn.net/en_joker/article/details/104407313

Cron表达式

Ref

是否必填 值以及范围 通配符
0-59 , - * /
0-59 , - * /
0-23 , - * /
1-31 , - * ? / L W
1-12 或 JAN-DEC , - * /
1-7 或 SUN-SAT , - * ? / L #
1970-2099 , - * /

需要说明的是,Cron 表达式中,“周” 是从周日开始计算的。“周” 域上的 1 表示的是周日,7 表示周六。

Cron中的通配符

  • , :指的是在两个以上的时间点中都执行。如果我在 “分” 这个域中定义为 8,12,35,则表示分别在第8分,第12分 第35分执行该定时任务。
    • :指定在某个域的连续范围。如果在 “时” 这个域中定义 1-6,则表示在 1 到 6 点之每小时都触发一次,等价于 1,2,3,4,5,6
    • :表示所有值,可解读为 “每”。 如果在 “日” 这个域中设置 *,表示每一天都会触发。
  • ? :表示不指定值。使用的场景为不需要关心当前设置这个字段的值。例如,要在每月的 8 号触发一个操作,但不关心是周几,我们可以这么设置 0 0 0 8 * ?
  • / :表示触发步进(step),”/“ 前面的值代表初始值( “*” 等同 “0”),后面的值代表偏移量,在某个域上周期性触发。比如 在 “秒” 上定义 5/10 表示从 第 5 秒开始,每 10 秒执行一次;而在 “分” 上则表示从 第 5 分钟开始,每 10 分钟执行一次。
  • L :表示英文中的 LAST 的意思,只能在 “日” 和 “周” 中使用。在 “日” 中设置,表示当月的最后一天(依据当前月份,如果是二月还会依据是否是润年), 在 “周” 上表示周六,相当于 “7” 或 “SAT”。如果在 “L” 前加上数字,则表示该数据的最后一个。例如在 “周” 上设置 “7L” 这样的格式,则表示 “本月最后一个周六”。
  • W :表示离指定日期的最近那个工作日(周一至周五)触发,只能在 “日” 中使用且只能用在具体的数字之后。若在 “日” 上置 “15W”,表示离每月 15 号最近的那个工作日触发。假如 15 号正好是周六,则找最近的周五(14号)触发;如果 15 号是周未,则找最近的下周一(16号)触发;如果 15 号正好在工作日(周一至周五),则就在该天触发。如果是 “1W” 就只能往本月的下一个最近的工作日推不能跨月往上一个月推。
  • : 例如,A#B 表示每月的第 B 个周的周 A(周的计数从周日开始),只能作用于 “周” 上。例如 2#3 表示在每月的第 3 个周二,5#3 表示本月第 3 周的星期四。

注意,L 用在 “周” 这个域上,每周最后一天是周六。“周” 域上的 1 表示的是周日,7 表示周六,即每周计数是从周日开始的。

可视化工具

在上述可视化工具网站上,点击“反解析到UI”,可以看到定时任务最近5次运行时间,便于理解。
另外,在IDEA中,安装 Cron Description 插件也可以进行可视化语义展示,如下图所示,鼠标悬浮到Cron表达式上,即可看到可视化语义。
定时任务介绍 - 图1

示例

下面给出一些示例,可根据上面的解释进行解读。

  • 每天晚上12点触发任务:0 0 0 ?
  • 每隔 1 分钟执行一次:0 /1 ?
  • 每月 1 号凌晨 1 点执行一次:0 0 1 1 * ?
  • 每月最后一天 23 点执行一次:0 0 23 L * ?
  • 每周周六凌晨 3 点实行一次:0 0 3 ? * L
  • 在24分,30分执行一次:0 24,30 * ?