关于cronExpression的介绍 ,定时任务

原创 2012年03月23日 10:10:56

关于cronExpression的介绍 

play的定时任务中会用到这个表达式

一个Cron-表达式是一个由六至七个字段组成由空格分隔的字符串,其中6个字段是必须的而一个是可选的,如下: 

字段名 

允许的值 

允许的特殊字符 

秒 

0-59 

, - * / 

分 

0-59 

, - * / 

小时 

0-23 

, - * / 

日 

1-31 

, - * ? / L W C 

月 

1-12 or JAN-DEC 

, - * / 

周几 

1-7 or SUN-SAT 

, - * ? / L C # 

年 (可选字段) 

empty, 1970-2099 

, - * / 

'*' 字符可以用于所有字段,在“分”字段中设为"*"表示"每一分钟"的含义。 

'?' 字符可以用在“日”和“周几”字段. 它用来指定 '不明确的值'. 这在你需要指定这两个字段中的某一个值而不是另外一个的时候会被用到。在后面的例子中可以看到其含义。 

'-' 字符被用来指定一个值的范围,比如在“小时”字段中设为"10-12"表示"10点到12点". 

',' 字符指定数个值。比如在“周几”字段中设为"MON,WED,FRI"表示"the days Monday, Wednesday, and Friday". 

'/' 字符用来指定一个值的的增加幅度. 比如在“秒”字段中设置为"0/15"表示"第0, 15, 30, 和 45秒"。而 "5/15"则表示"第5, 20, 35, 和 50". 在'/'前加"*"字符相当于指定从0秒开始. 每个字段都有一系列可以开始或结束的数值。对于“秒”和“分”字段来说,其数值范围为0到59,对于“小时”字段来说其为0到23, 对于“日”字段来说为0到31, 而对于“月”字段来说为1到12。"/"字段仅仅只是帮助你在允许的数值范围内从开始"第n"的值。 因此 对于“月”字段来说"7/6"只是表示7月被开启而不是“每六个月”, 请注意其中微妙的差别。 

'L'字符可用在“日”和“周几”这两个字段。它是"last"的缩写, 但是在这两个字段中有不同的含义。例如,“日”字段中的"L"表示"一个月中的最后一天" —— 对于一月就是31号对于二月来说就是28号(非闰年)。而在“周几”字段中, 它简单的表示"7" or "SAT",但是如果在“周几”字段中使用时跟在某个数字之后, 它表示"该月最后一个星期×" —— 比如"6L"表示"该月最后一个周五"。当使用'L'选项时,指定确定的列表或者范围非常重要,否则你会被结果搞糊涂的。 

'W' 可用于“日”字段。用来指定历给定日期最近的工作日(周一到周五) 。比如你将“日”字段设为"15W",意为: "离该月15号最近的工作日"。因此如果15号为周六,触发器会在14号即周五调用。如果15号为周日, 触发器会在16号也就是周一触发。如果15号为周二,那么当天就会触发。然而如果你将“日”字段设为"1W", 而一号又是周六, 触发器会于下周一也就是当月的3号触发,因为它不会越过当月的值的范围边界。'W'字符只能用于“日”字段的值为单独的一天而不是一系列值的时候。 

'L'和'W'可以组合用于“日”字段表示为'LW',意为"该月最后一个工作日"。 

'#' 字符可用于“周几”字段。该字符表示“该月第几个周×”,比如"6#3"表示该月第三个周五( 6表示周五而"#3"该月第三个)。再比如: "2#1" = 表示该月第一个周一而 "4#5" = 该月第五个周三。注意如果你指定"#5"该月没有第五个“周×”,该月是不会触发的。 

'C' 字符可用于“日”和“周几”字段,它是"calendar"的缩写。 它表示为基于相关的日历所计算出的值(如果有的话)。如果没有关联的日历, 那它等同于包含全部日历。“日”字段值为"5C"表示"日历中的第一天或者5号以后",“周几”字段值为"1C"则表示"日历中的第一天或者周日以后"。 

对于“月份”字段和“周几”字段来说合法的字符都不是大小写敏感的。 

下面是一些完整的例子: 

表达式 

含义 

"0 0 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分每分钟一次触发 

"0 0/5 14 * * ?" 

每天从下午2点开始到2:55分结束每5分钟一次触发 

"0 0/5 14,18 * * ?" 

每天的下午2点至2:55和6点至6点55分两个时间段内每5分钟一次触发 

"0 0-5 14 * * ?" 

每天14:00至14:05每分钟一次触发 

"0 10,44 14 ? 3 WED" 

三月的每周三的14:10和14: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" 

每月最后一个周五的10:15触发 

"0 15 10 ? * 6L 2002-2005" 

2002年至2005年的每月最后一个周五的10:15触发 

"0 15 10 ? * 6#3" 

每月的第三个周五的10:15触发 


@On("0 0 3 * * ?")//每天凌晨3点触发
public class Clear extends Job {
public void doJob() {
Logger.info("更新......");
}
}





play框架使用起来(5)

1、逆向生成URL Play路由器是按照Java调用生成URL的,所以可以将URI表达式都集中到同个配置文件中,使得重构应用变得更加便捷。比如,为conf/routes文件添加如下路...
  • zyhlal
  • zyhlal
  • 2016年11月03日 14:55
  • 981

play框架使用起来(7)

1 高级HTTP绑定# 简单类型       Play可以实现所有Java原生的简单数据类型的自动转换,主要包括:int,long,boolean,char,byte,float,...
  • zyhlal
  • zyhlal
  • 2016年11月03日 16:04
  • 1597

spring定时任务时间格式cronExpression设置

spring定时任务时间格式cronExpression设置

spring定时任务时间格式cronExpression设置

org.springframework.scheduling.quartz.CronTriggerBean允许你更精确地控制任务的运行时间,只需要设置其cronExpression属性。 一个c...

Spring Quartz 定时任务cronexpression详解

关于cronExpression表达式,这里讲解一下: 字段 允许值 允许的特殊字符 秒 0-59 , - * / 分 0-59 , - * / 小时 0-23 , - * / 日期 1-31 , -...

spring 定时任务 CronExpression时间表达式编写

表达式中的域有6个必填项,一个可选项,其中year是可选的 Field Name   Allowed Values   Allowed Spe...

spring定时任务时间格式cronExpression设置(转载)

org.springframework.scheduling.quartz.CronTriggerBean允许你更精确地控制任务的运行时间,只需要设置其cronExpression属性。 一...

(转)Quartz在Spring中动态设置cronExpression (spring设置动态定时任务)

2007-07-25 13:52 什么是动态定时任务:是由客户制定生成的,服务端只知道该去执行什么任务,但任务的定时是不确定的(是由客户制定)。 这样总不能修改配置文件每定制个...
  • hy2203
  • hy2203
  • 2011年12月06日 22:18
  • 210

定时任务中,cronExpression的设置规则

单纯针对时间的设置规则 org.springframework.scheduling.quartz.CronTriggerBean允许你更精确地控制任务的运行时间,只需要设置其cronExpress...

cronExpression表达式解释(spring定时任务)

0 0 12 * * ?---------------在每天中午12:00触发  0 15 10 ? * *---------------每天上午10:15 触发  0 15 10 * * ?--...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:关于cronExpression的介绍 ,定时任务
举报原因:
原因补充:

(最多只允许输入30个字)