Universe 帮助中心

10.3 如何设置任务定时策略

创建于 2022-11-03 / 最近更新于 2022-11-09 / 1314
字体: [默认] [大] [更大]

数据开发平台可以设置灵活的定时策略。

对于开发人员来说,在做项目的过程中或多或少都会用到定时任务,Universe也会使用定时任务调度框架,定时任务表达式都是必不可少的。

Universe上的定时策略是由cron表达式写的。

平时配置cron表达式,基本上都是把别人写好的表达式样例复制过来修修改改就好了。当然现在也有许多网站提供了在线生成cron表达式的功能,我们只要按照规则填写就可以轻松的得到cron表达式。但是作为一个合格的开发人员来说,掌握基本的cron表达式原理还是很有必要的。即使定时任务没有按预期去调度执行,也能快速的定位到问题所在。

image.png

cron表达式

我们就从一个简单的cron表达式例子开始,cron = 0 0 2 * * ? ,这个表达式的含义是每天凌晨两点执行一次任务。可以看到cron表达式是一个字符串,以5或者6个空格隔开(示例中是被5个空格隔开)。字符串被切割为6个或者7个域,每个域都代表不同的含义。从左到右依次为"秒 分 时 日 月 星期几 年" ,其中年不是必须的的,所以cron表达式有两种形式:

各个域的含义如下:

image.png

每个域都可以用数字表示,但是还可以出现如下特殊字符。

  • * : 表示匹配该域的任意值。比如Minutes域使用*,就表示每分钟都会触发。

  • - : 表示范围。比如Minutes域使用 10-20,就表示从10分钟到20分钟每分钟都会触发一次。

  • , : 表示列出枚举值。比如Minutes域使用1,3,就表示1分钟和3分钟都会触发一次。

  • / : 表示间隔时间触发(开始时间/时间间隔)。例如在Minutes域使用 5/10,就表示从第5分钟开始,每隔10分钟触发一次。

  • ? : 表示不指定值。简单理解就是忽略该字段的值,直接根据另一个字段的值触发执行。

  • # : 表示该月第n个星期x(x#n),仅用星期域。如:星期:6#3,表示该月的第三个星期五。

  • L : 表示最后,是单词"last"的缩写(最后一天或最后一个星期几);仅出现在日和星期的域中。用在日则表示该月的最后一天,用在星期则表示该月的最后一个星期。如:星期域上的值为5L,则表示该月最后一个星期的星期四。在使用'L'时,不要指定列表','或范围'-',否则易导致出现意料之外的结果。

  • W: 仅用在日的域中,表示距离当月给定日期最近的工作日(周一到周五),是单词"weekday"的缩写。

比如:"4W"表示距离4号最近的工作日(当月的)触发;

(1)当4号就是工作日时,则表示当天触发;当4号为周六时,则表示3号(周五)触发;

(2)当4号为周日时,则表示在5号(周一)触发;

比如:"1W"表示距离1号最近的工作日触发事件,但是,该工作日只算当月的。假如当月1号是周六,则"1W"表示在当月3号(周一)触发。就算上个月的最后一天是工作日,也不会触发。

  • LW: ‘L’和'W'可以一起组合在日字段使用。表示当月的最后一个工作日触发事件。

取值说明

DayofMonth:

可以用数字1-31 中的任一个值,但要注意一些特别的月份。

Month:

一年中的月份,可以用0-11 或用字符串 “JAN, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV and DEC” 表示。

DayofWeek:

表示星期几,可以用数字1-7(1=星期日),或者用字符串"SUN, MON, TUE, WED, THU, FRI and SAT"来表示。

常用cron表达式

*/10 * * * * ? 每隔10秒执行一次

0 */5 * * * ? 每隔5分钟执行一次

0 2,22,32 * * * ? 在2分、22分、32分执行一次

0 0 4-8 * * ? 每天4-8点整点执行一次

0 0 2 * * ? 每天凌晨2点执行一次

0 0 2 1 * ? 每月1号凌晨2点执行一次

cron表达式生成器

现在也有一些在线的cron表达式生成器,如:

https://www.toolzl.com/tools/croncreate.html

可以直接界面化的方式生成cron表达式


0 人点赞过