本文中含有需要您注意的重要提示信息,忽略该信息可能对您的业务造成影响,请务必仔细阅读。
本文档详细介绍了阿里云IDaaS EIAM中Cron表达式的语法规则和使用方法,帮助您正确配置定时任务调度。
什么是Cron表达式?
Cron表达式是一种用于配置定时任务的时间表达式,由6个或7个字段组成的字符串,字段之间用空格分隔,每个字段代表一个时间单位。
基本语法
Cron 语法格式:
秒 分 时 日 月 星期 【年】
每个域允许的值
字段位置
时间单位
取值范围
允许的特殊字符
1
秒(Seconds)
0–59
- * /
2
分(Minutes)
0–59
- * /
3
小时(Hours)
0–23
- * /
4
日期(Day of month)
1–31
- * ? / L W C
5
月份(Month)
1–12 或 JAN–DEC
JAN-DEC - * /
6
星期(Day of week)
0–7(0 和 7 都是周日)或 SUN–SAT
SUN-SAT - * ? / L C #
7(可选)
年(Year)
留空或1970–2199(可选字段)
, - * /
特殊字符说明
字符 | 含义 | 说明 |
* | 表示匹配域的任意值 | 在分这个域使用 *,即表示每分钟都会触发事件。 |
? | 表示匹配域的任意值,但只能用在日期和星期两个域,因为这两个域会相互影响。 | 要在每月的 20 号触发调度,不管每个月的 20 号是星期几,则只能使用如下写法: |
- | 表示起止范围 | 在分这个域使用 5-20,表示从 5 分到 20 分钟每分钟触发一次。 |
/ | 表示起始时间开始触发,然后每隔固定时间触发一次 | 在分这个域使用 5/20,表示在第 5 分钟触发一次,之后每 20 分钟触发一次,即 5、 25、45 等分别触发一次。 |
, | 表示列出枚举值 | 在分这个域使用 5,20,则意味着在 5 和 20 分每分钟触发一次。 |
L | 表示最后,只能出现在日和星期两个域 | 在星期这个域使用 5L,意味着在最后的一个星期四触发。 |
W | 表示有效工作日(周一到周五),只能出现在日这个域,系统将在离指定日期最近的有效工作日触发事件。 | 在日这个域使用 5W,如果 5 号是星期六,则将在最近的工作日星期五,即 4 号触发。如果 5 号是星期天,则在 6 号(周一)触发;如果 5 号为工作日,则就在 5 号触发。另外,W 的最近寻找不会跨过月份。 |
LW | 这两个字符可以连用,表示在某个月最后一个工作日,即最后一个星期五。 | |
# | 表示每个月第几个星期几,只能出现在星期这个域 | 在星期这个域使用 4#2,表示某月的第二个星期三,4 表示星期三,2 表示第二个。 |
常用示例
IDaaS 身份提供方中的 Cron 表达式要求间隔在1小时以上,建议合理控制间隔,以免数据同步的频率不符合您的预期。
示例 | 说明 |
| 每2小时执行一次 |
| 每月 1 日的凌晨 2 点执行一次 |
| 周一到周五每天上午 10:15 执行作业 |
| 每天 23 点执行一次 |
| 每天凌晨 1 点执行一次 |
| 每月 1 日凌晨 1 点执行一次 |
| 每月最后一天 23 点执行一次 |
| 每周星期天凌晨 1 点执行一次 |
| 每天的 0 点、13 点、18 点、21 点都执行一次 |
| 每天上午 10 点,下午 2 点,4 点执行一次 |
| 每个星期三中午 12 点执行一次 |
| 每天中午 12 点触发 |
| 每天上午 10:15 触发 |
| 每天上午 10:15 触发 |
| 每天上午 10:15 触发 |
| 2025 年的每天上午 10:15 触发 |
| 每月 15 日上午 10:15 触发 |
| 每月最后一日的上午 10:15 触发 |
| 每月的最后一个星期五上午 10:15 触发 |
| 2025 年至 2026 年的每月的最后一个星期五上午 10:15 触发 |
| 每月的第三个星期五上午 10:15 触发 |
本示例中的时间参数(包括年份),可根据您的实际需求灵活调整。