深入浅出系列之cron表达式详解

    技术2026-03-26  15

    cron表达式

    定义

    Cron表达式是一个字符串,字符串以5或6个空格隔开,分为6或7个域,每一个域代表一个含义;

    Cron表达式有如下两种语法格式:

    秒 分 时 日 月 周 年(可选)秒 分 时 日 月 周

    cron表达式结构

    Seconds (秒)Minutes(分)Hours(小时)Day-of-Month (天)Month(月)Day-of-Week (周)Year(年)

    各字段的含义

    字段允许值允许的特殊字符秒(Seconds)0~59的整数, - * / 四个字符分(Minutes)0~59的整数, - * / 四个字符小时(Hours)0~23的整数, - * / 四个字符日期(DayofMonth)1~31的整数(但是你需要考虑你月的天数),- * ? / L W C 八个字符月份(Month)1~12的整数或者 JAN-DEC, - * / 四个字符星期(DayofWeek)1~7的整数或者 SUN-SAT (1=SUN), - * ? / L C # 八个字符年(可选)(Year)留空 1970~2099, - * / 四个字符

    各字符的意义

    特殊字符意义*任意值。假如在Minutes域使用*, 即表示每分钟都会触发事件?只能用在日期域和星期域中使用,它被用来指定"非明确的值"-表示范围。例如在分钟域使用5-20,表示从5分到20分钟每分钟触发一次,指定几个可选值,例如:在Minutes域使用5,20,则意味着在每小时中的5分钟和20分钟触发一次/指定增量,例如在Minutes域使用0/15,则意味着每小时的0,15,30,45分钟,分别触发一次L表示最后,只能出现在DayofWeek和DayofMonth域,如果在DayofWeek域使用5L,意味着在最后的一个星期四触发W表示有效工作日(周一到周五),只能出现在DayofMonth域,系统将在离指定日期的最近的有效工作日触发事件。例如:在 DayofMonth使用5W,如果5日是星期六,则将在最近的工作日:星期五,即4日触发。如果5日是星期天,则在6日(周一)触发;如果5日在星期一到星期五中的一天,则就在5日触发LW这两个字符可以连用,表示在某个月最后一个工作日,即最后一个星期五#用于确定每个月第几个星期几,只能出现在星期域。例如在4#2,表示某月的第二个星期三C允许在日期域和星期域出现。这个字符依靠一个指定的“日历”。也就是说这个表达式的值依赖于相关的“日历”的计算结果,如果没有“日历”关联,则等价于所有包含的“日历”。如:日期域是“5C”表示关联“日历”中第一天,或者这个月开始的第一天的后5天。星期域是“1C”表示关联“日历”中第一天,或者星期的第一天的后1天,也就是周日的后一天(周一)

    常用表达式例子

    0 0 2 1 * ? * 表示在每月的1日的凌晨2点调整任务0 15 10 ? * MON-FRI 表示周一到周五每天上午10:15执行作业0 15 10 ? 6L 2002-2006 表示2002-2006年的每个月的最后一个星期五上午10:15执行作0 0 10,14,16 * * ? 每天上午10点,下午2点,4点0 0/30 9-17 * * ? 朝九晚五工作时间内每半小时0 0 12 ? * WED 表示每个星期三中午12点0 0 12 * * ? 每天中午12点触发0 15 10 ? * * 每天上午10:15触发0 15 10 * * ? 每天上午10:15触发0 15 10 * * ? * 每天上午10:15触发0 15 10 * * ? 2005 2005年的每天上午10:15触发0 * 14 * * ? 在每天下午2点到下午2:59期间的每1分钟触发0 0/5 14 * * ? 在每天下午2点到下午2:55期间的每5分钟触发0 0/5 14,18 * * ? 在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发0 0-5 14 * * ? 在每天下午2点到下午2:05期间的每1分钟触发0 10,44 14 ? 3 WED 每年三月的星期三的下午2:10和2:44触发0 15 10 ? * MON-FRI 周一至周五的上午10:15触发0 15 10 15 * ? 每月15日上午10:15触发0 15 10 L * ? 每月最后一日的上午10:15触发0 15 10 ? * 6L 每月的最后一个星期五上午10:15触发0 15 10 ? * 6L 2002-2005 2002年至2005年的每月的最后一个星期五上午10:15触发0 15 10 ? * 6#3 每月的第三个星期五上午10:15触发
    Processed: 0.013, SQL: 9