AnalyticDB PostgreSQL版设置周期执行的计划时,需要使用Cron表达式,本文为您介绍什么是Cron表达式以及相关示例。

Cron表达式是一个具有时间含义的字符串,字符串以5~6个空格隔开,分为6~7个域,格式为秒 分钟 小时 日期 月份 星期 年。最后一个代表年份的域非必须,可省略。单个域有多个取值时,使用半角逗号(,)隔开取值。每个域可以是确定的取值,也可以是通配符。

域取值

下表为Cron表达式中六个域的取值范围以及支持的通配符。

是否必需 取值范围 通配符
[0, 59] * , - /
分钟 [0, 59] * , - /
小时 [0, 23] * , - /
日期 [1, 31] * , - / ? L W
月份 [1, 12]或[JAN, DEC] * , - /
星期 [1, 7]或[MON, SUN]。若您使用[1, 7]表达方式,1代表星期一,7代表星期日。 * , - / ? L #
[1970,2099] * , - /

通配符

Cron表达式中的每个域都支持通配符,每个通配符有其特殊含义。

通配符 含义 示例
* 所有值。 在月域中,*表示每个月;在星期域中,*表示星期的每一天。
, 列出枚举值。 在分钟域中,5,20表示分别在5分钟和20分钟触发一次。
- 范围。 在分钟域中,5-20表示从5分钟到20分钟之间每分钟触发一次。
/ 指定数值的增量。 在分钟域中,0/15表示从第0分钟开始,每15分钟触发一次。3/20表示从第3分钟开始,每20分钟触发一次。
? 不指定值。仅日期和星期域支持该字符。 当日期或星期域其中之一被指定了值以后,为了避免冲突,需要将另一个域的值设为?
L 单词Last的首字母,表示最后一天。仅日期和星期域支持该字符。
说明 指定L字符时,避免指定列表或者范围,否则,会导致逻辑问题。
  • 在日期域中,L表示某个月的最后一天。在星期域中,L表示一个星期的最后一天,即星期日(SUN)。
  • 如果在L前有数字,则表示最后一个该数字代表的时间。例如,在星期域中的6L表示这个月的最后一个星期六。
W 除周末以外的工作日,在离指定日期的最近的工作日触发事件。W字符寻找最近工作日时不会跨过当前月份,连用字符LW时表示为指定月份的最后一个工作日。仅日期域支持该字符。 在日期域中5W,如果5日是星期六,则将在最近的工作日星期五,即4日触发。如果5日是星期天,则将在最近的工作日星期一,即6日触发。如果5日在星期一到星期五中的一天,则就在5日触发。
# 每个月第几个星期几。仅星期域支持该字符。 在星期域中,4#2表示某月的第二个星期四。

示例

以下为Cron表达式的取值示例。

注意 计划管理的Cron表达式使用的是UTC时间,实际使用时请将北京时间转换成UTC时间。
场景 示例(场景为UTC时间时) 示例(场景为北京时间时)
每天上午10:15执行计划 0 15 10 ? * * 0 15 18 ? * *
每天上午10:15执行计划 0 15 10 * * ? 0 15 18 * * ?
每天中午12:00执行计划 0 0 12 * * ? 0 0 20 * * ?
每天上午10:00点、下午14:00以及下午16:00执行计划 0 0 10,14,16 * * ? 0 0 18,22,0 * * ?
每天上午09:00到下午17:00时间段内每隔半小时执行计划 0 0/30 9-17 * * ? 0 0/30 17-2 * * ?
每天下午14:00到下午14:59时间段内每隔1分钟执行计划 0 * 14 * * ? 0 * 22 * * ?
每天下午14:00到下午14:05时间段内每隔1分钟执行计划 0 0-5 14 * * ? 0 0-5 22 * * ?
每天下午14:00到下午14:55时间段内每隔5分钟执行计划 0 0/5 14 * * ? 0 0/5 22 * * ?
每天下午14:00到下午14:55、下午18:00到下午18:55时间段内每隔5分钟执行计划 0 0/5 14,18 * * ? 0 0/5 22,3 * * ?
每个星期三中午12:00执行计划 0 0 12 ? * WED 0 0 20 ? * WED
每月15日上午10:15执行计划 0 15 10 15 * ? 0 15 18 15 * ?
每月最后一日上午10:15执行计划 0 15 10 L * ? 0 15 18 L * ?
每月最后一个星期六上午10:15执行计划 0 15 10 ? * 6L 0 15 18 ? * 6L
每月第三个星期六上午10:15执行计划 0 15 10 ? * 6#3 0 15 18 ? * 6#3
每年3月的每个星期三下午14:10和14:44执行计划 0 10,44 14 ? 3 WED 0 10,44 22 ? 3 WED
2022年每天上午10:15执行计划 0 15 10 ? * * 2022 0 15 18 ? * * 2022
每年每天上午10:15执行计划 0 15 10 ? * * * 0 15 18 ? * * *
2022年每天下午14:00到下午14:55、下午18:00到下午18:55时间段内每隔5分钟执行计划 0 0/5 14,18 * * ? 2022 0 0/5 22,3 * * ? 2022
2022年至2023年每月第三个星期六上午10:15执行计划 0 15 10 ? * 6#3 2022,2023 0 15 18 ? * 6#3 2022,2023
2022年至2025年每天上午09:00到下午17:30时间段内每隔半小时执行计划 0 0/30 9-17 * * ? 2022-2025 0 0/30 17-2 * * ? 2022-2025
从2022年开始,每隔两年3月的每个星期三下午14:10和14:44执行计划 0 10,44 14 ? 3 WED 2022/2 0 10,44 22 ? 3 WED 2022/2