• quartz CronExpression


    一、Quartz Cron 表达式支持到七个域    

    名称

    是否必须

    允许值

    特殊字符

    0-59

    , - * /

    0-59

    , - * /

    0-23

    , - * /

    1-31

    , - * ? / L W C

    1-12 或 JAN-DEC

    , - * /

    1-7 或 SUN-SAT

    , - * ? / L C #

    空 或 1970-2099

    , - * /

    二、Quartzcron 特殊字符

      * 星号  

      使用星号(*) 指示着你想在这个域上包含所有合法的值。例如,在月份域上使用星号意味着每个月都会触发这个 trigger。

      表达式样例:

      0 * 17 * * ?

      意义:每天从下午5点到下午5:59中的每分钟激发一次 trigger。它停在下午5:59 是因为值 17 在小时域上,在下午 6 点时,小时变为 18 了,也就不再理会这个trigger,直到下一天的下午5点。

      在你希望 trigger 在该域的所有有效值上被激发时使用* 字符。



      ? 问号



      ? 号只能用在日和周域上,但是不能在这两个域上同时使用。你可以认为 ? 字符是"我并不关心在该域上是什么值。" 这不同于星号,星号是指示着该域上的每一个值。? 是说不为该域指定值。

      不能同时这两个域上指定值的理由是难以解释甚至是难以理解的。基本上,假定同时指定值的话,意义就会变得含混不清了:考虑一下,如果一个表达式在日域上有值11,同时在周域上指定了 WED。那么是要 trigger 仅在每个月的11号,且正好又是星期三那天被激发?还是在每个星期三的11号被激发呢?要去除这种不明确性的办法就是不能同时在这两个域上指定值。

      只要记住,假如你为这两域的其中一个指定了值,那就必须在另一个字值上放一个 ?。

      表达式样例:

      0 10,44 14 ? 3 WEB

      意义:在三月中的每个星期三的下午 2:10 和下午 2:44 被触发。



      , 逗号



      逗号 (,) 是用来在给某个域上指定一个值列表的。例如,使用值 0,15,30,45 在秒域上意味着每15秒触发一个 trigger。

      表达式样例:

      0 0,15,30,45 * * * ?

      意义:每刻钟触发一次 trigger。



      / 斜杠



      斜杠 (/) 是用于时间表的递增的。我们刚刚用了逗号来表示每15分钟的递增,但是我们也能写成这样0/15。

      表达式样例:

      0/15 0/30 * * * ?

      意义:在整点和半点时每15秒触发trigger。



      - 中划线



      中划线 (-) 用于指定一个范围。例如,在小时域上的 3-8 意味着"3,4,5,6,7 和 8 点。" 域的值不允许回卷,所以像 50-10 这样的值是不允许的。

      表达式样例:

      0 45 3-8 ? * *

      意义:在上午的3点至上午的8点的45分时触发trigger。



      L 字母



      L 说明了某域上允许的最后一个值。它仅被日和周域支持。当用在日域上,表示的是在月域上指定的月份的最后一天。例如,当月域上指定了 JAN 时,在日域上的 L 会促使 trigger 在1月31号被触发。假如月域上是 SEP,那么 L 会预示着在9月30号触发。换句话说,就是不管指定了哪个月,都是在相应月份的时最后一天触发 trigger。

      表达式 0 0 8 L * ? 意义是在每个月最后一天的上午8:00 触发 trigger。在月域上的 * 说明是 "每个月"。

      当 L 字母用于周域上,指示着周的最后一天,就是星期六 (或者数字7)。所以如果你需要在每个月的最后一个星期六下午的 11:59 触发trigger,你可以用这样的表达式 0 59 23 ? * L。

      当使用于周域上,你可以用一个数字与 L 连起来表示月份的最后一个星期X。例如,表达式 0 0 12 ? * 2L 说的是在每个月的最后一个星期一触发 trigger。

      不要让范围和列表值与 L 连用

      虽然你能用星期数(1-7)与 L 连用,但是不允许你用一个范围值和列表值与 L 连用。这会产生不可预知的结果。


      W 字母



      W 字符代表着平日 (Mon-Fri),并且仅能用于日域中。它用来指定离指定日的最近的一个平日。大部分的商业处理都是基于工作周的,所以 W 字符可能是非常重要的。例如,日域中的 15W 意味着"离该月15号的最近一个平日。"假如15号是星期六,那么trigger 会在14号(星期四)触发,因为距15号最近的是星期一,这个例子中也会是17号(译者Unmi注:不会在17号触发的,如果是15W,可能会是在14号(15号是星期六)或者15号(15号是星期天)触发,也就是只能出现在邻近的一天,如果15号当天为平日直接就会当日执行)。W只能用在指定的日域为单天,不能是范围或列表值。

      # 井号



      # 字符仅能用于周域中。它用于指定月份中的第几周的哪一天。例如,如果你指定周域的值为 6#3,它意思是某月的第三个周五(6=星期五,#3意味着月份中的第三周)。另一个例子 2#1 意思是某月的第一个星期一 (2=星期一,#1意味着月份中的第一周)。注意,假如你指定 #5,然而月份中没有第 5 周,那么该月不会触发。

    三、cron表达式各占位符解释   

      {秒数} ==> 允许值范围: 0~59 ,不允许为空值,若值不合法,调度器将抛出SchedulerException异常

      "*" 代表每隔1秒钟触发;

      "," 代表在指定的秒数触发,比如"0,15,45"代表0秒、15秒和45秒时触发任务

      "-" 代表在指定的范围内触发,比如"25-45"代表从25秒开始触发到45秒结束触发,每隔1秒触发1次

      "/" 代表触发步进(step),"/"前面的值代表初始值("*"等同"0"),后面的值代表偏移量,比如"0/20"或者"*/20"代表从0秒钟开始,每隔20秒钟触发1次,即0秒触发  1次,20秒触发1次,40秒触发1次;"5/20"代表5秒触发1次,25秒触发1次,45秒触发1次;"10-45/20"代表在[10,45]内步进20秒命中的时间点触发,即10秒触发1次,30秒触发1次

      {分钟} ==> 允许值范围: 0~59 ,不允许为空值,若值不合法,调度器将抛出SchedulerException异常

      "*" 代表每隔1分钟触发;

      "," 代表在指定的分钟触发,比如"10,20,40"代表10分钟、20分钟和40分钟时触发任务

      "-" 代表在指定的范围内触发,比如"5-30"代表从5分钟开始触发到30分钟结束触 发,每隔1分钟触发

      "/" 代表触发步进(step),"/"前面的值代表初始值("*"等同"0"),后面的值代表偏移量,比如"0/25"或者"*/25"代表从0分钟开始,每隔25分钟触发1次,即0分钟触发1次,第25分钟触发1次,第50分钟触发1次;"5/25"代表5分钟触发1次,30分钟触发1次,55分钟触发1次;"10-45/20"代表在[10,45]内步进20分钟命中的时间点触发,即10分钟触发1次,30分钟触发1次

      {小时} ==> 允许值范围: 0~23 ,不允许为空值,若值不合法,调度器将抛出SchedulerException异常

      "*" 代表每隔1小时触发;

      "," 代表在指定的时间点触发,比如"10,20,23"代表10点钟、20点钟和23点触发任务

      "-" 代表在指定的时间段内触发,比如"20-23"代表从20点开始触发到23点结束触发,每隔1小时触发

      "/" 代表触发步进(step),"/"前面的值代表初始值("*"等同"0"),后面的值代表偏移量,比如"0/1"或者"*/1"代表从0点开始触发,每隔1小时触发1次;"1/2"代表从1点开始触发,以后每隔2小时触发一次;"19-20/2"表达式将只在19点触发

      {日期} ==> 允许值范围: 1~31 ,不允许为空值,若值不合法,调度器将抛出SchedulerException异常

      "*" 代表每天触发;

      "?" 与{星期}互斥,即意味着若明确指定{星期}触发,则表示{日期}无意义,以免引起 冲突和混乱

      "," 代表在指定的日期触发,比如"1,10,20"代表1号、10号和20号这3天触发

      "-" 代表在指定的日期范围内触发,比如"10-15"代表从10号开始触发到15号结束触发,每隔1天触发

      "/" 代表触发步进(step),"/"前面的值代表初始值("*"等同"1"),后面的值代表偏移量,比如"1/5"或者"*/5"代表从1号开始触发,每隔5天触发1次;"10/5"代表从10号开始触发,以后每隔5天触发一次;"1-10/2"表达式意味着在[1,10]范围内,每隔2天触发,即1号,3号,5号,7号,9号触发

      "L" 如果{日期}占位符如果是"L",即意味着当月的最后一天触发

      "W "意味着在本月内离当天最近的工作日触发,所谓最近工作日,即当天到工作日的前后最短距离,如果当天即为工作日,则距离为0;所谓本月内的说法,就是不能跨月取到最近工作日,即使前/后月份的最后一天/第一天确实满足最近工作日;因此,"LW"则意味着本月的最后一个工作日触发,"W"强烈依赖{月份}

    "C" 根据日历触发,由于使用较少,暂时不做解释

      {月份} ==> 允许值范围: 1~12 (JAN-DEC),不允许为空值,若值不合法,调度器将抛出SchedulerException异常

      "*" 代表每个月都触发;

      "," 代表在指定的月份触发,比如"1,6,12"代表1月份、6月份和12月份触发任务

      "-" 代表在指定的月份范围内触发,比如"1-6"代表从1月份开始触发到6月份结束触发,每隔1个月触发

    "/" 代表触发步进(step),"/"前面的值代表初始值("*"等同"1"),后面的值代表偏移量,比如"1/2"或者"*/2"代表从1月份开始触发,每隔2个月触发1次;"6/6"代表从6月份开始触发,以后每隔6个月触发一次;"1-6/12"表达式意味着每年1月份触发

      {星期} ==> 允许值范围: 1~7 (SUN-SAT),1代表星期天(一星期的第一天),以此类推,7代表星期六(一星期的最后一天),不允许为空值,若值不合法,调度器将抛出SchedulerException异常

      "*" 代表每星期都触发;

      "?" 与{日期}互斥,即意味着若明确指定{日期}触发,则表示{星期}无意义,以免引起冲突和混乱

      "," 代表在指定的星期约定触发,比如"1,3,5"代表星期天、星期二和星期四触发

      "-" 代表在指定的星期范围内触发,比如"2-4"代表从星期一开始触发到星期三结束触发,每隔1天触发

      "/" 代表触发步进(step),"/"前面的值代表初始值("*"等同"1"),后面的值代表偏移量,比如"1/3"或者"*/3"代表从星期天开始触发,每隔3天触发1次;"1-5/2"表达式意味着在[1,5]范围内,每隔2天触发,即星期天、星期二、星期四触发

      "L" 如果{星期}占位符如果是"L",即意味着星期的的最后一天触发,即星期六触发,L= 7或者 L = SAT,因此,"5L"意味着一个月的最后一个星期四触发

      "#" 用来指定具体的周数,"#"前面代表星期,"#"后面代表本月第几周,比如"2#2"表示本月第二周的星期一,"5#3"表示本月第三周的星期四,因此,"5L"这种形式只不过是"#"的特殊形式而已

      "C" 根据日历触发,由于使用较少,暂时不做解释

      {年份} ==> 允许值范围: 1970~2099 ,允许为空,若值不合法,调度器将抛出SchedulerException异常

      "*"代表每年都触发;

      ","代表在指定的年份才触发,比如"2011,2012,2013"代表2011年、2012年和2013年触发任务

      "-"代表在指定的年份范围内触发,比如"2011-2020"代表从2011年开始触发到2020年结束触发,每隔1年触发

      "/"代表触发步进(step),"/"前面的值代表初始值("*"等同"1970"),后面的值代表偏移量,比如"2011/2"或者"*/2"代表从2011年开始触发,每隔2年触发1次

    四、经典案例

      

     1 "30 * * * * ?" 每半分钟触发任务
     2 
     3 "30 10 * * * ?" 每小时的10分30秒触发任务
     4 
     5 "30 10 1 * * ?" 每天1点10分30秒触发任务
     6 
     7 "30 10 1 20 * ?" 每月20号1点10分30秒触发任务
     8 
     9 "30 10 1 20 10 ? *" 每年10月20号1点10分30秒触发任务
    10 
    11 "30 10 1 20 10 ? 2011" 2011年10月20号1点10分30秒触发任务
    12 
    13 "30 10 1 ? 10 * 2011" 2011年10月每天1点10分30秒触发任务
    14 
    15 "30 10 1 ? 10 SUN 2011" 2011年10月每周日1点10分30秒触发任务
    16 
    17 "15,30,45 * * * * ?" 每15秒,30秒,45秒时触发任务
    18 
    19 "15-45 * * * * ?" 15到45秒内,每秒都触发任务
    20 
    21 "15/5 * * * * ?" 每分钟的每15秒开始触发,每隔5秒触发一次
    22 
    23 "15-30/5 * * * * ?" 每分钟的15秒到30秒之间开始触发,每隔5秒触发一次
    24 
    25 "0 0/3 * * * ?" 每小时的第0分0秒开始,每三分钟触发一次
    26 
    27 "0 15 10 ? * MON-FRI" 星期一到星期五的10点15分0秒触发任务
    28 
    29 "0 15 10 L * ?" 每个月最后一天的10点15分0秒触发任务
    30 
    31 "0 15 10 LW * ?" 每个月最后一个工作日的10点15分0秒触发任务
    32 
    33 "0 15 10 ? * 5L" 每个月最后一个星期四的10点15分0秒触发任务
    34 
    35 "0 15 10 ? * 5#3" 每个月第三周的星期四的10点15分0秒触发任务

      

     1 0 0 12 * * ?    每天12点触发    
     2 
     3 0 15 10 ? * *    每天10点15分触发    
     4 
     5 0 15 10 * * ?    每天10点15分触发    
     6 
     7 0 15 10 * * ? *    每天10点15分触发    
     8 
     9 0 15 10 * * ? 2005    2005年每天10点15分触发    
    10 
    11 0 * 14 * * ?    每天下午的 2点到2点59分每分触发    
    12 
    13 0 0/5 14 * * ?    每天下午的 2点到2点59分(整点开始,每隔5分触发)    
    14 
    15 0 0/5 14,18 * * ?    每天下午的 2点到2点59分、18点到18点59分(整点开始,每隔5分触发)    
    16 
    17 0 0-5 14 * * ?    每天下午的 2点到2点05分每分触发    
    18 
    19 0 10,44 14 ? 3 WED    3月分每周三下午的 2点10分和2点44分触发    
    20 
    21 0 15 10 ? * MON-FRI    从周一到周五每天上午的10点15分触发    
    22 
    23 0 15 10 15 * ?    每月15号上午10点15分触发    
    24 
    25 0 15 10 L * ?    每月最后一天的10点15分触发    
    26 
    27 0 15 10 ? * 6L    每月最后一周的星期五的10点15分触发    
    28 
    29 0 15 10 ? * 6L 2002-2005    从2002年到2005年每月最后一周的星期五的10点15分触发    
    30 
    31 0 15 10 ? * 6#3    每月的第三周的星期五开始触发    
    32 
    33 0 0 12 1/5 * ?    每月的第一个中午开始每隔5天触发一次    
    34 
    35 0 11 11 11 11 ?    每年的11月11号 11点11分触发(光棍节)   

       参考资料1:https://blog.csdn.net/qq_38890137/article/details/80467824

      参考资料2:https://www.cnblogs.com/pipi-changing/p/5697481.html

      参考资料3:https://www.cnblogs.com/yaowen/p/3779284.html

  • 相关阅读:
    好书推介《实战机器学*》
    Web技术图书名单
    大数据技术书,看看有没有感兴趣的
    博客园设置自定义皮肤,添加自定义小模块悬浮天气组件,github图标链接等
    Final Cut Pro 视频剪辑学习记录,快捷操作等
    css 利用 clip-path 裁剪多边形,三角形,梯形,六边形等
    有呀,有呀,设计!有呀,有呀,组件!
    github README添加badge标识,多彩的tag标签
    vue timeline 开箱即用的时间轴组件,日志更新时间轴组件
    那些需要收藏的网站网址
  • 原文地址:https://www.cnblogs.com/hyunbar/p/10412435.html
Copyright © 2020-2023  润新知