Quartz Cron 表达式(时间格式的写法)
- 格式:pdf
- 大小:48.40 KB
- 文档页数:1
Quartz学习--quartz基本介绍和Cron表达式表名称说明qrtz_blob_triggers Trigger作为Blob类型存储(⽤于Quartz⽤户⽤JDBC创建他们⾃⼰定制的Trigger类型,JobStore 并不知道如何存储实例的时候)qrtz_calendars以Blob类型存储Quartz的Calendar⽇历信息, quartz可配置⼀个⽇历来指定⼀个时间范围负责执⾏向QuartzScheduler注册的触发Trigger的⼯作线程ThreadPool :Scheduler使⽤⼀个线程作为任务运⾏的基础设施,任务通过共享线程池中的线程提⾼运⾏效率QuartzSchedulerResources :包含穿件QuartzScheduler实例所需的所有资源(JobStore,ThreadPool等)JobStore :通过类实现的接⼝,这些类要为org.quartz.core.QuartzScheduler的使⽤提供⼀个org.quartz.Job和org.quartz.Trigger存储机制.作业和触发器的存储应该以其名称和组的组合为唯⼀性QuartzScheduler :Quartz的核⼼,他是org.quartz.Scheduler接⼝的间接实现,包含调度org.quartz.Jobs ,注册org.quartz.JobListener实例等的⽅法Scheduler :这是Quartz Scheduler的主要接⼝,代表⼀个独⽴运⾏容器. 调度程序维护JobDetails和触发器的注册表.⼀旦注册,调度程序负责执⾏作业,当她们的相关连的触发器触发(当她们的预定时间到达时 )Trigger:具有所有触发器通⽤属性的基本接⼝,描述了job执⾏的时间触发规则,使⽤TriggerBuilder实例化实际触发器JobDetail :传递给定作业实例的详细信息属性.JobDetails将使⽤JobBuilder创建/定义Job :表⽰要执⾏的"作业"的类的实现接⼝.只有⼀个⽅法:void execute(JobExecutionContext context);(JobExecutionContext 提供调度上下⽂各种信息,运⾏时数据保存在jobDataMap中 )Job 有个⼦接⼝StatefulJob,代表没有状态任务有状态任务不可并发,前次任务没有执⾏完,后⾯任务则⼀直处于阻塞等待状态2. ⼀个job可以被多个Trigger 绑定,但是⼀个Trigger只能绑定⼀个job!7. quartz.properties Quartz可更改配置//调度标识名集群中每⼀个实例都必须使⽤相同的名称(区分特定的调度器实例)org.quartz.scheduler.instanceName:DefaultQuartzScheduler//ID设置为⾃动获取每⼀个必须不同(所有调度器实例中是唯⼀的)org.quartz.scheduler.instanceId :AUTO//数据保存⽅式为持久化org.quartz.jobStore.class :org.quartz.impl.jdbcjobstore.JobStoreTX//表的前缀org.quartz.jobStore.tablePrefix : QRTZ_//设置为TRUE不会出现序列化⾮字符串类到 BLOB 时产⽣的类版本问题//eProperties : true//加⼊集群 true 为集群 false不是集群org.quartz.jobStore.isClustered : false//调度实例失效的检查时间间隔org.quartz.jobStore.clusterCheckinInterval:20000//容许的最⼤作业延长时间org.quartz.jobStore.misfireThreshold :60000//ThreadPool 实现的类名org.quartz.threadPool.class:org.quartz.simpl.SimpleThreadPool//线程数量org.quartz.threadPool.threadCount : 10//线程优先级org.quartz.threadPool.threadPriority : 5(threadPriority 属性的最⼤值是常量 ng.Thread.MAX_PRIORITY,等于10。
quartz 时间表达式
Quartz时间表达式是一种用于定义任务调度计划的格式。
它基于CRON表达式,并添加了一些额外的功能。
Quartz时间表达式的格式如下:
{秒数} {分钟} {小时} {日期} {月份} {星期} [{年份}]
其中,方括号中的年份可选,在未指定时表示任务在每一年都会执行。
以下是Quartz时间表达式的一些示例:
- "0 0 12 * * ?" 表示每天中午12点执行任务。
- "0 0/5 * * * ?" 表示每5分钟执行一次任务。
- "0 15 10 ? * MON-FRI" 表示每周一至周五的上午10点15分执行任务。
- "0 0 12 ? * 6L" 表示每月最后一个星期五的中午12点执行任务。
在Quartz时间表达式中,还可以使用一些特殊字符,如:
- *(星号):匹配任意值。
- ?(问号):表示不确定的值,通常用于日期或星期的字段中。
- -(短横线):表示范围。
- ,(逗号):表示多个值。
- /(斜杠):表示步进值。
使用这些特殊字符可以更灵活地定义任务的调度计划。
Cron表达式被用来配置CronTrigger实例。
Cron表达式是一个字符串,字符串以5或6个空格隔开,分开为6或7个域,每一个域代表一个含义。
Cron有如下两种语法格式:Seconds Minutes Hours DayofMonth Month DayofWeek Year 或Seconds Minutes Hours DayofMonth Month DayofWeek每个子表达式都描述了一个单独的日程细节。
这些子表达式用空格分隔,分别表示:1.Seconds 秒,可出现,- * / 四个字符,有效范围为0-59的整数2.Minutes 分钟,可出现,- * / 四个字符,有效范围为0-59的整数3.Hours 小时,可出现,- * / 四个字符,有效范围为0-23的整数4.Day-of-Month 月中的天,可出现,- * / ? L W C八个字符,有效范围为0-31的整数5.Month 月,可出现,- * / 四个字符,有效范围为1-12的整数或JAN-DEc6.Day-of-Week 周中的天,可出现,- * / ? L C #八个字符,有效范围为1-7的整数或SUN-SAT两个范围。
1表示星期天,2表示星期一,依次类推7.Year (optional field) 年(可选的域),可出现,- * / 四个字符,有效范围为1970-2099年每一个域都使用数字,但还可以出现如下特殊字符,它们的含义是:(1)*:表示匹配该域的任意值,假如在Minutes域使用*,即表示每分钟都会触发事件。
(2)?:只能用在DayofMonth和DayofWeek两个域。
它也匹配域的任意值,但实际不会。
因为DayofMonth和DayofWeek会相互影响。
例如想在每月的20日触发调度,不管20日到底是星期几,则只能使用如下写法:13 13 15 20 * ?,其中最后一位只能用?,而不能使用*,如果使用*表示不管星期几都会触发,实际上并不是这样。
Quartz中时间参数说明即Cron表达式Cron表达式Quartz使用类似于Linux下的Cron表达式定义时间规则,Cron表达式由6或7个由空格分隔的时间字段组成,如表1所示:表1 Cron表达式时间字段Cron表达式的时间字段除允许设置数值外,还可使用一些特殊的字符,提供列表、范围、通配符等功能,细说如下:●星号(*):可用在所有字段中,表示对应时间域的每一个时刻,例如,*在分钟字段时,表示“每分钟”;●问号(?):该字符只在日期和星期字段中使用,它通常指定为“无意义的值”,相当于点位符;●减号(-):表达一个范围,如在小时字段中使用“10-12”,则表示从10到12点,即10,11,12;●逗号(,):表达一个列表值,如在星期字段中使用“MON,WED,FRI”,则表示星期一,星期三和星期五;●斜杠(/):x/y表达一个等步长序列,x为起始值,y为增量步长值。
如在分钟字段中使用0/15,则表示为0,15,30和45秒,而5/15在分钟字段中表示5,20,35,50,你也可以使用*/y,它等同于0/y;●L:该字符只在日期和星期字段中使用,代表“Last”的意思,但它在两个字段中意思不同。
L在日期字段中,表示这个月份的最后一天,如一月的31号,非闰年二月的28号;如果L 用在星期中,则表示星期六,等同于7。
但是,如果L出现在星期字段里,而且在前面有一个数值X,则表示“这个月的最后X天”,例如,6L表示该月的最后星期五;●W:该字符只能出现在日期字段里,是对前导日期的修饰,表示离该日期最近的工作日。
例如15W表示离该月15号最近的工作日,如果该月15号是星期六,则匹配14号星期五;如果15日是星期日,则匹配16号星期一;如果15号是星期二,那结果就是15号星期二。
但必须注意关联的匹配日期不能够跨月,如你指定1W,如果1号是星期六,结果匹配的是3号星期一,而非上个月最后的那天。
W字符串只能指定单一日期,而不能指定日期范围;●LW组合:在日期字段可以组合使用LW,它的意思是当月的最后一个工作日;●井号(#):该字符只能在星期字段中使用,表示当月某个工作日。
quartz的cron表达式Quartz的Cron表达式简介1. 什么是Cron表达式Cron表达式是一种用于定时任务调度的标准格式。
在Quartz框架中,Cron表达式被广泛使用,用于设置任务的执行时间。
2. Cron表达式的语法Cron表达式由6个或7个字段组成,每个字段代表时间的一个维度。
这6个或7个字段分别是:•秒(0~59)•分钟(0~59)•小时(0~23)•日(1~31)•月(1~12)•周几(0~7,0和7都代表周日)可以使用通配符或范围来表示时间的不确定性。
例如,“*“代表所有可能的值,”?“在日和周几字段中代表不指定值,”-“用来表示范围,” / “用来表示递增间隔。
例如,要设置每天早上9点执行任务,Cron表达式可以是0 0 9 ? * *。
3. 常用的Cron表达式示例以下是一些常见的Cron表达式示例:•0 0/5 * * * ?表示每隔5分钟执行一次任务。
•0 0 12 * * ?表示每天中午12点执行任务。
•0 0 8 ? * MON-FRI表示周一到周五每天早上8点执行任务。
•0 0 8 ? * 6L表示每个月的最后一个周五早上8点执行任务。
4. Cron表达式的高级用法Cron表达式还支持一些高级功能,例如使用”#“指定月份中的第几个周几,使用”L”指定月份中的最后一天,使用”W”指定平日最近的工作日等等。
以下是一些高级用法的示例:•0 0 12 ? JAN,FEB,DEC *表示一月、二月和十二月每天中午12点执行任务。
•0 0/30 9-17 * * MON-FRI#2表示周一到周五上午9点到下午5点之间,每隔30分钟执行一次任务,并且每个月的第二个周一符合条件。
5. 总结Cron表达式是Quartz框架中用于指定任务执行时间的标准格式。
它非常灵活,并且支持多种时间维度的设置。
掌握Cron表达式的语法和常用示例,可以帮助我们轻松实现定时任务的调度。
6. Cron表达式的注意事项在使用Cron表达式时,需要注意以下几点:•时间表达式字段之间使用空格分隔。
org.springframework.scheduling.quartz.CronTriggerBean允许你更精确地控制任务的运行时间,只需要设置其cronExpression属性。
一个cronExpression表达式有至少6个(也可能是7个)由空格分隔的时间元素。
从左至右,这些元素的定义如下:1.秒(0–59)2.分钟(0–59)3.小时(0–23)4.月份中的日期(1–31)5.月份(1–12或JAN–DEC)6.星期中的日期(1–7或SUN–SAT)7.年份(1970–2099)0 0 10,14,16 * * ? 每天上午10点,下午2点和下午4点0 0,15,30,45 * 1-10 * ? 每月前10天每隔15分钟30 0 0 1 1 ? 2012 在2012年1月1日午夜过30秒时0 0 8-5 ? * MON-FRI 每个工作日的工作时间各个时间可用值如下:秒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秒‖。
调度Quartz时间格式配置1、 CronTrigger时间格式配置说明CronTrigger配置格式:格式: [秒] [分] [⼩时] [⽇] [⽉] [周] [年]通配符说明:* :表⽰所有值. 例如:在分的字段上设置 "*",表⽰每⼀分钟都会触发。
:表⽰不指定值。
使⽤的场景为不需要关⼼当前设置这个字段的值。
例如:要在每⽉的10号触发⼀个操作,但不关⼼是周⼏,所以需要周位置的那个字段设置为"?" 具体设置为 0 0 0 10 * ?- :表⽰区间。
例如在⼩时上设置 "10-12",表⽰ 10,11,12点都会触发。
, :表⽰指定多个值,例如在周字段上设置 "MON,WED,FRI" 表⽰周⼀,周三和周五触发/ :⽤于递增触发。
如在秒上⾯设置"5/15" 表⽰从5秒开始,每增15秒触发(5,20,35,50)。
在⽉字段上设置'1/3'所⽰每⽉1号开始,每隔三天触发⼀次。
L :表⽰最后的意思。
在⽇字段设置上,表⽰当⽉的最后⼀天(依据当前⽉份,如果是⼆⽉还会依据是否是润年[leap]), 在周字段上表⽰星期六,相当于"7"或"SAT"。
如果在"L"前加上数字,则表⽰该数据的最后⼀个。
例如在周字段上设置"6L"这样的格式,则表⽰“本⽉最后⼀个星期五"W :表⽰离指定⽇期的最近那个⼯作⽇(周⼀⾄周五). 例如在⽇字段上设置"15W",表⽰离每⽉15号最近的那个⼯作⽇触发。
如果15号正好是周六,则找最近的周五(14号)触发, 如果15号是周未,则找最近的下周⼀(16号)触发.如果15号正好在⼯作⽇(周⼀⾄周五),则就在该天触发。
如果指定格式为 "1W",它则表⽰每⽉1号往后最近的⼯作⽇触发。
一个cron表达式有至少6个(也可能7个)有空格分隔的时间元素。
按顺序依次为:秒(0~59)分钟(0~59)小时(0~23)天(月)(0~31,但是你需要考虑你月的天数)月(0~11)天(星期(1~7 1=SUN 或 SUN,MON,TUE,WED,THU,FRI,SAT)年份(1970-2099)格式如下:字段允许值允许的特殊字符秒 0-59 , - * /分 0-59 , - * /小时 0-23 , - * /日期 1-31 , - * ? / L W C月份 1-12 或者 JAN-DEC , - * /星期 1-7 或者 SUN-SAT , - * ? / L C #年(可选)留空, 1970-2099 , - * /其中每个元素可以是:一个值(如6),一个连续区间(9-12),一个间隔时间(8-18/4)(/表示每隔4小时),一个列表(1,3,5),通配符。
由于"月份中的日期"和"星期中的日期"这两个元素互斥的,必须要对其中一个设置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触发Cron表达式的时间字段除允许设置数值外,还可使用一些特殊的字符,提供列表、范围、通配符等功能,细说如下:●星号(*):可用在所有字段中,表示对应时间域的每一个时刻,例如,*在分钟字段时,表示“每分钟”;●问号(?):该字符只在日期和星期字段中使用,它通常指定为“无意义的值”,相当于点位符;●减号(-):表达一个范围,如在小时字段中使用“10-12”,则表示从10到12点,即10,11,12;●逗号(,):表达一个列表值,如在星期字段中使用“MON,WED,FRI”,则表示星期一,星期三和星期五;●斜杠(/):x/y表达一个等步长序列,x为起始值,y为增量步长值。
Quartz及Cron表达式QuartzQuartz是一个完全由java编写的开源作业调度框架.Quartz最主要的功能就是调度器(完成定时任务),可以与javaEE 或者javaSE应用程序相结合也可以单独使用。
Quartz能借助关系数据库和JDBC作业存储支持集群,负载均衡。
Spring QuartzSpring中继承并简化了Quartz, 我们可以通过配置Spring简化Quartz的配置。
在ApplicationContext.xml配置数据源,并且引入ApplicationContext-quartz.xml文件。
ApplicationContext.xml:Xml代码1.<bean id="dataSource" class="org.springframework.jndi. JndiObjectFactoryBean">2.<property name="jndiName" value="java:comp/env/jdbc /publicdb"></property>3.</bean>4..5..6..7..8.<!-- import -->9.<import resource="ApplicationContext-quartz.xml" />[xml] view plain copy1.<bean id="dataSource" class="org.springframework.jndi. JndiObjectFactoryBean">2.<property name="jndiName" value="java:comp/env/jdbc/publicdb"></property>3.</bean>4..5..6..7..8.<!-- import -->9.<import resource="ApplicationContext-quartz.xml" />ApplicationContext-quartz.xml:Java代码1.<?xml version="1.0" encoding="UTF-8"?>2.<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "/dtd/spring-beans.dtd"> 3.4.<beans default-autowire="byName">5.<!-- 要调用的工作类 -->6.<bean id="reportCreateJob" class="org.quartz.JobDetail" >7.<property name="jobClass">8.<value>com.hundsun.u3c.reportserver.quartz.job.Report CreateJob</value>9.</property>10.<property name="name" value="reportCreate-processor-job" />11.</bean>12.<!-- 定义触发时间 -->13.<bean id="reportCreateTrigger" class="org.springfra mework.scheduling.quartz.CronTriggerBean">14.<property name="jobDetail">15.<ref bean="reportCreateJob" />16.</property>17.<property name="cronExpression">18.<value>0 * * * * ?</value>19.</property>20.</bean>21.<!-- 管理类:配置Schedule信息,与spring容器的生命周期建立联系等功能 -->22.<bean id="scheduler"23.class="org.springframework.scheduling.quartz.Schedu lerFactoryBean">24.<property name="dataSource" ref="dataSource" />25.<!-- 在SchedulerFactoryBean初始化完成后,延迟300秒启动Scheduler,以便让Spring能够更快初始化容器中剩余的Bean。
Cron表达式说明Quartz使用类似于Linux下的Cron表达式定义时间规则,Cron表达式由6或7个由空格分隔的时间字段组成,如表1所示:表1 Cron表达式时间字段Cron表达式的时间字段除允许设置数值外,还可使用一些特殊的字符,提供列表、范围、通配符等功能,细说如下:●星号(*):可用在所有字段中,表示对应时间域的每一个时刻,例如,*在分钟字段时,表示“每分钟”;●问号(?):该字符只在日期和星期字段中使用,它通常指定为“无意义的值”,相当于点位符;●减号(-):表达一个范围,如在小时字段中使用“10-12”,则表示从10到12点,即10,11,12;●逗号(,):表达一个列表值,如在星期字段中使用“MON,WED,FRI”,则表示星期一,星期三和星期五;●斜杠(/):x/y表达一个等步长序列,x为起始值,y为增量步长值。
如在分钟字段中使用0/15,则表示为0,15,30和45秒,而5/15在分钟字段中表示5,20,35,50,你也可以使用*/y,它等同于0/y;●L:该字符只在日期和星期字段中使用,代表“Last”的意思,但它在两个字段中意思不同。
L在日期字段中,表示这个月份的最后一天,如一月的31号,非闰年二月的28号;如果L用在星期中,则表示星期六,等同于7。
但是,如果L出现在星期字段里,而且在前面有一个数值X,则表示“这个月的最后X天”,例如,6L表示该月的最后星期五;●W:该字符只能出现在日期字段里,是对前导日期的修饰,表示离该日期最近的工作日。
例如15W表示离该月15号最近的工作日,如果该月15号是星期六,则匹配14号星期五;如果15日是星期日,则匹配16号星期一;如果15号是星期二,那结果就是15号星期二。
但必须注意关联的匹配日期不能够跨月,如你指定1W,如果1号是星期六,结果匹配的是3号星期一,而非上个月最后的那天。
W字符串只能指定单一日期,而不能指定日期范围;●LW组合:在日期字段可以组合使用LW,它的意思是当月的最后一个工作日;●井号(#):该字符只能在星期字段中使用,表示当月某个工作日。
Quartz中时间表达式的设置-----corn表达式时间格式: <!-- s m h d m w(?) y(?) -->, 分别对应: 秒>分>小时>日>月>周>年, 举例:1.每天什么时候执行:<value>0 59 23 * * ?</value>: 如下为每天23:59:00开始执行<value>0 1,2,3 11,12 * * ? </value>: 每天11:01,11:02,11:03;12:01,12:02,12:03分执行任务2.每隔多久执行:汇总说明:Cron表达式的时间字段除允许设置数值外,还可使用一些特殊的字符,提供列表、范围、通配符等功能,细说如下:●星号(*):可用在所有字段中,表示对应时间域的每一个时刻,例如,*在分钟字段时,表示“每分钟”;●问号(?):该字符只在日期和星期字段中使用,它通常指定为“无意义的值”,相当于点位符;●减号(-):表达一个范围,如在小时字段中使用“10-12”,则表示从10到12点,即10,11,12;●逗号(,):表达一个列表值,如在星期字段中使用“MON,WED,FRI”,则表示星期一,星期三和星期五;●斜杠(/):x/y表达一个等步长序列,x为起始值,y为增量步长值。
如在分钟字段中使用0/15,则表示为0,15,30和45秒,而5/15在分钟字段中表示5,20,35,50,你也可以使用*/y,它等同于0/y;==================================================Quartz cron 表达式的格式十分类似于UNIX cron 格式,但还是有少许明显的区别。
区别之一就是Quartz 的格式向下支持到秒级别的计划,而UNIX cron 计划仅支持至分钟级。
许多我们的触发计划要基于秒级递增的(例如,每45秒),因此这是一个非常好的差异。
时间表达式-----Cron表达式详解序⾔Cron表达式:就是⽤简单的xxoo符号按照⼀定的规则,就能把各种时间维度表达的淋漓尽致,⽆所不在其中,然后在⽤来做任务调度(定时服务)的中所认知执⾏,可想⽽知这是多么的天⾐⽆缝,说是编码艺术凝集⼀点不过分。
⽜逼吹完啦,我就写⼏个简单的cron表达式欣赏下:1、0/20 * * * * ? note:每20秒2、15 0/2 * * * ?note:每⼩时从0分钟开始,每2分钟的第15秒,假如当前时间是20:00:00,那么他的维度就在:20:02:5,20:04:15,20:06:15 ....3、0 0/2 17-21 * * ?note: 每天的下午5点到晚上9点,每隔2分中的第00秒,假如当前时间是20:24:52 ,那么他的时间维度在:20:26:00,20:28:00,20:30:00 ...看到Cron表达式的简洁与强⼤并存,忍不住往下深⼊,GoCron表达式的符号、格式表格表1、cron表达式特殊字符意义⽰意表特殊字符意义*匹配所有的值。
如:*在分钟的字段域⾥表⽰每分钟只在⽇期域和星期域中使⽤。
它被⽤来指定“⾮明确的值”-指定⼀个范围。
如:“10-12”在⼩时域意味着“10点、11点、12点”,指定⼏个可选值。
如:“MON,WED,FRI”在星期域⾥表⽰“星期⼀、星期三、星期五”/指定增量。
如:“0/15”在秒域意思是没分钟的0,15,30和45秒。
“5/15”在分钟域表⽰没⼩时的5,20,35和50。
符号“*”在“/”前⾯(如:*/10)等价于0在“/”前⾯(如:0/10)L表⽰day-of-month和day-of-week域,但在两个字段中的意思不同,例如day-of-month域中表⽰⼀个⽉的最后⼀天。
如果在day-of-week域表⽰‘7’或者‘SAT’,如果在day-of-week域中前⾯加上数字,它表⽰⼀个⽉的最后⼏天,例如‘6L’就表⽰⼀个⽉的最后⼀个星期五W只允许⽇期域出现。
quart 定时规则
Quartz定时规则的语法是一种基于cron的表达式,它允许你定义在特定时间执行的计划任务。
以下是Quartz定时规则的一些常见符号和用法:
1. 秒(0-59)
2. 分(0-59)
3. 小时(0-23)
4. 日期(1-31)
5. 月份(1-12 或 JAN-DEC)
6. 星期(0-7 或 SUN-SAT,其中0和7都表示SAT)
你可以使用这些字段来定义任务的执行时间。
例如:
"0 0 12 ?" 表示每天中午12点执行任务。
"0 15 10 ? MON-FRI" 表示每周一到周五的上午10点15分执行任务。
"0 0/15 9-17 ?" 表示在每天的上午9点到下午5点之间,每小时执行一次任务。
"0 0 9 1/15 ?" 表示每月的1号、15号的上午9点执行任务。
"0 0 12 1/2 ?" 表示每两个月的1号中午12点执行任务。
"0 0 0 25 12 ?" 表示每年的12月25日午夜执行任务。
这只是Quartz定时规则的一些基本示例,你可以根据自己的需求来定义更
复杂的表达式。
请注意,Quartz定时规则的具体语法可能因不同的编程语
言或框架而有所差异,因此建议查阅相关语言的文档以获得准确的语法规范。
quartz cron 表达式判断条件摘要:1.介绍quartz cron 表达式2.quartz cron 表达式的构成3.判断条件4.具体示例正文:## 1.介绍quartz cron 表达式Quartz 是一个流行的开源任务调度框架,它允许用户通过cron 表达式来定义任务的执行时间。
cron 表达式是一种基于Unix 的定时任务表达式,它可以用来配置任务的执行间隔和执行时间。
## 2.quartz cron 表达式的构成一个典型的quartz cron 表达式由以下几个部分组成:- 分钟(0-59)- 小时(0-23)- 天数(1-31)- 月份(1-12)- 星期几(0-7,0 表示星期日,1 表示星期一,以此类推)这些部分之间用空格隔开,构成了一个完整的cron 表达式。
例如,"0/15 * * * *"表示每15 分钟执行一次。
## 3.判断条件在quartz 中,可以通过cron 表达式来判断任务的执行条件。
具体来说,quartz 会比较当前时间和任务的cron 表达式,如果当前时间符合cron 表达式,那么任务就会被执行。
## 4.具体示例假设我们有一个任务,它的执行条件是每小时执行一次,我们可以通过以下cron 表达式来定义这个任务:```0 */1 * * *```这个表达式的意思是,每小时的第0 分钟执行任务。
例如,如果当前时间是10:00,那么这个任务就会在10:00 执行。
如果当前时间是10:30,那么这个任务就不会执行,因为已经过了每小时的第0 分钟。
这就是如何使用quartz cron 表达式来判断任务的执行条件。
quartz cron 表达式判断条件Quartz Cron 表达式判断条件简介•Quartz是一个开源的任务调度框架,可以用于按照指定时间规则执行任务。
•Cron表达式是Quartz中最常用的时间规则表达方式,用于定义任务的执行计划。
Cron表达式概述•Cron表达式由6或7个字段组成,分别表示秒、分、时、天、月、周和年(可选)。
•每个字段都可以包含多个取值,取值之间用逗号分隔。
•支持的特殊字符包括星号(表示任意值)、问号(表示不指定值)、斜杠(表示步长)、连字符(表示范围)、逗号(表示枚举值)等。
Cron表达式示例以下是一些常见的Cron表达式示例:1.每天的凌晨1点执行:–0 0 1 * * ?2.每个月的1号凌晨执行:–0 0 0 1 * ?3.每天的上午10点到下午2点之间,每隔5分钟执行一次:–0 0/5 10-14 * * ?4.每周一到周五的上午9点执行:–0 0 9 ? * MON-FRICron表达式判断条件在Quartz中,可以使用Cron表达式作为任务调度的判断条件。
以下是一些常见的Cron表达式判断条件的示例:•每天执行任务:–0 0 0 * * ?•每小时执行任务:–0 0 * * * ?•每分钟执行任务:–0 * * * * ?•每秒钟执行任务:–* * * * * ?•每个月的第一天执行任务:–0 0 0 1 * ?•每周一到周五的上午9点执行任务:–0 0 9 ? * MON-FRI•每天的上午9点到下午5点,每隔1个小时执行任务:–0 0 9-17 * * ?总结Quartz中的Cron表达式为我们提供了一种灵活、精确的任务调度方式。
通过合理使用Cron表达式的判断条件,我们可以轻松实现按需自动执行任务。
因此,掌握Cron表达式的判断条件是非常重要的,相信通过本文的介绍,读者对此有了更深入的了解。
以上便是关于Quartz Cron表达式判断条件的相关内容,希望对读者有所帮助!高级用法在上一部分我们介绍了一些常见的Cron表达式判断条件,现在我们来探讨一些更高级的用法。
标题:深度解析quartz cronexpression的例子一、介绍在软件开发中,时间调度是一个非常常见和重要的功能。
quartz是一个功能强大的开源调度框架,它提供了丰富的功能来满足各种调度需求。
其中,cronexpression是quartz中用来描述触发时间的一种表达式,它非常灵活和强大,但同时也比较复杂。
本文将围绕quartz cronexpression的例子展开深入探讨。
二、什么是cronexpressioncronexpression是一种时间表达式,它用于描述在特定时间点触发任务的规则。
在quartz中,cronexpression通常被用于定义触发Job 的时间规则。
它由6个字段组成,分别表示秒、分钟、小时、日期、月份和星期几。
每个字段都可以使用特定的符号来描述不同的时间规则,比如数字、星号、斜线等。
通过组合这些符号,就可以构建出非常灵活和精确的调度规则。
三、quartz cronexpression的例子1. 每天凌晨1点触发任务在cronexpression中,表示每天凌晨1点触发任务的表达式为:"0 0 1 * * ?"。
其中,第一个字段表示秒,第二个字段表示分钟,第三个字段表示小时,然后是日期、月份和星期几。
使用这个cronexpression 就可以实现每天凌晨1点触发任务的功能。
2. 每隔5分钟触发任务如果需要每隔5分钟触发一次任务,对应的cronexpression为:"00/5 * * * ?"。
这个表达式中,第二个字段使用了斜线符号表示间隔5分钟,其他字段保持不变。
使用这个cronexpression就可以实现每隔5分钟触发任务的功能。
3. 每周一、三、五的上午10点触发任务要实现每周一、三、五的上午10点触发任务,对应的cronexpression为:"0 0 10 ? * MON,WED,FRI"。
CronTrigger配置格式:格式: [秒] [分] [小时] [日] [月] [周] [年]序号说明是否必填允许填写的值允许的通配符1 秒是 0-59 , - * /2 分是 0-59 , - * /3 小时是 0-23 , - * /4 日是 1-31 , - * ? / L W5 月是 1-12 or JAN-DEC , - * /6 周是 1-7 or SUN-SAT , - * ? / L #7 年否 empty 或1970-2099 , - * /通配符说明:* 表示所有值. 例如:在分的字段上设置"*",表示每一分钟都会触发。
?表示不指定值。
使用的场景为不需要关心当前设置这个字段的值。
例如:要在每月的10号触发一个操作,但不关心是周几,所以需要周位置的那个字段设置为"?" 具体设置为0 0 0 10 * ?-表示区间。
例如在小时上设置"10-12",表示10,11,12点都会触发。
,表示指定多个值,例如在周字段上设置"MON,WED,FRI" 表示周一,周三和周五触发/ 用于递增触发。
如在秒上面设置"5/15" 表示从5秒开始,每增15秒触发(5,20,35,50)。
在月字段上设置'1/3'所示每月1号开始,每隔三天触发一次。
L表示最后的意思。
在日字段设置上,表示当月的最后一天(依据当前月份,如果是二月还会依据是否是润年[leap]), 在周字段上表示星期六,相当于"7"或"SAT"。
如果在"L"前加上数字,则表示该数据的最后一个。
例如在周字段上设置"6L"这样的格式,则表示“本月最后一个星期五"W表示离指定日期的最近那个工作日(周一至周五). 例如在日字段上设置"15W",表示离每月15号最近的那个工作日触发。
quartznet cron-like表达式详解【摘要】QuartzNet是一个开源的作业调度框架,其cron-like表达式是一种常用的时间表达式,用于指定作业的执行时间。
本文从介绍什么是quartznet cron-like表达式开始,详细解释了其结构和特殊字符的含义。
通过例子展示了如何使用这种表达式,并提出了使用注意事项。
文章最后总结了quartznet cron-like表达式的重要性、灵活性和应用场景,强调了其在作业调度中的重要作用。
通过本文的阐述,读者可以更加深入地了解和应用这种时间表达式,提高作业调度的效率和精准度。
【关键词】quartznet, cron-like表达式, 结构, 特殊字符, 例子, 注意事项, 重要性, 灵活性, 应用1. 引言1.1 quartznet cron-like表达式详解QuartzNet 是一个开源的任务调度框架,它允许用户根据特定的时间表来调度任务的执行。
在QuartzNet 中,cron-like 表达式被广泛应用,它提供了一个灵活且强大的方式来定义任务的执行时间。
本文将详细介绍QuartzNet 中的cron-like 表达式,帮助读者更好地理解和使用该功能。
QuartzNet 中的cron-like 表达式由多个字段组成,每个字段表示一个时间单位(如秒、分、时等)。
通过设置这些字段的值,可以精确地定义任务的执行时间。
除了常见的数字值外,cron-like 表达式还支持一些特殊字符,例如通配符、范围、间隔等,以满足更复杂的调度需求。
在使用QuartzNet 中的cron-like 表达式时,需要注意一些细节和注意事项,以避免出现意外情况。
理解每个字段的含义和取值范围,避免设置冲突的规则,确保表达式的正确性等。
只有在深入理解和正确使用cron-like 表达式的情况下,才能发挥其强大的功能和灵活性。
2. 正文2.1 什么是quartznet cron-like表达式QuartzNet是一个开源的任务调度库,它允许用户根据预定的时间表来执行任务。
QuartZCron表达式Cron Expressionscron的表达式被⽤来配置CronTrigger实例。
cron的表达式是字符串,实际上是由七⼦表达式,描述个别细节的时间表。
这些⼦表达式是分开的空⽩,代表:1. Seconds2. Minutes3. Hours4. Day-of-Month5. Month6. Day-of-Week7. Year (可选字段)8.例 "0 0 12 ? * WED" 在每星期三下午12:00 执⾏,个别⼦表达式可以包含范围;例如,在前⾯的例⼦⾥("WED")可以替换成 "MON-FRI", "MON, WED, FRI"甚⾄"MON-WED,SAT".“*” 代表整个时间段.每⼀个字段都有⼀套可以指定有效值,如Seconds (秒) :可以⽤数字0-59表⽰,Minutes(分) :可以⽤数字0-59表⽰,Hours(时) :可以⽤数字0-23表⽰,Day-of-Month(天) :可以⽤数字1-31中的任⼀⼀个值,但要注意⼀些特别的⽉份Month(⽉) :可以⽤0-11或⽤字符串 “JAN, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV and DEC” 表⽰Day-of-Week(每周) :可以⽤数字1-7表⽰(1=星期⽇)或⽤字符⼝串“SUN, MON, TUE, WED, THU, FRI and SAT”表⽰ “*”:指定所有的值,⽐如,Minutes 设置为 *,表⽰每分钟“/”:为特别单位,表⽰为“每”如“0/15”表⽰每隔15分钟执⾏⼀次,“0”表⽰为从“0”分开始, “3/20”表⽰表⽰每隔20分钟执⾏⼀次,“3”表⽰从第3分钟开始执⾏ “?”:表⽰每⽉的某⼀天,或第周的某⼀天 “L”:⽤于每⽉,或每周,表⽰为每⽉的最后⼀天,或每个⽉的最后星期⼏如“6L”表⽰“每⽉的最后⼀个星期五” “W”:表⽰为最近⼯作⽇,如“15W”放在每⽉(day-of-month)字段上表⽰为“到本⽉15⽇最近的⼯作⽇” “#”:是⽤来指定“的”每⽉第n个⼯作⽇,例在每周(day-of-week)这个字段中内容为"6#3" or "FRI#3" 则表⽰“每⽉第三个星期五”注意: Day-of-Month 和 Day-of-Week不可同时为 * ,否则报错:1 ng.RuntimeException: CronExpression '0/2 * * * * * *' is invalid.23 at org.quartz.CronScheduleBuilder.cronSchedule(CronScheduleBuilder.java:111)4 at quartz.QuartzExample.getTrigger(QuartzExample.java:110)5 at quartz.QuartzExample.run(QuartzExample.java:74)6 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)7 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)8 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)9 at ng.reflect.Method.invoke(Method.java:606)10 at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)11 at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)12 at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)13 at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)14 at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)15 at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)16 at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)17 at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)18 at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)19 at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)20 at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)21 at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)22 at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)23 at org.junit.runners.ParentRunner.run(ParentRunner.java:363)24 at org.junit.runner.JUnitCore.run(JUnitCore.java:137)25 at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68)26 at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:51)27 at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242)28 at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70)29 Caused by: java.text.ParseException: Support for specifying both a day-of-week AND a day-of-month parameter is not implemented.30 at org.quartz.CronExpression.buildExpression(CronExpression.java:511)31 at org.quartz.CronExpression.<init>(CronExpression.java:276)32 at org.quartz.CronScheduleBuilder.cronSchedule(CronScheduleBuilder.java:107)33 ... 25 more3435 Disconnected from the target VM, address: '127.0.0.1:61437', transport: 'socket'3637 Process finished with exit code -1RuntimeExceptionCronExpression 源码:protected void buildExpression(String expression) throws ParseException {expressionParsed = true;try {if (seconds == null) {seconds = new TreeSet<Integer>();}if (minutes == null) {minutes = new TreeSet<Integer>();}if (hours == null) {hours = new TreeSet<Integer>();}if (daysOfMonth == null) {daysOfMonth = new TreeSet<Integer>();}if (months == null) {months = new TreeSet<Integer>();}if (daysOfWeek == null) {daysOfWeek = new TreeSet<Integer>();}if (years == null) {years = new TreeSet<Integer>();}int exprOn = SECOND;StringTokenizer exprsTok = new StringTokenizer(expression, " \t",false);while (exprsTok.hasMoreTokens() && exprOn <= YEAR) {String expr = exprsTok.nextToken().trim();// throw an exception if L is used with other days of the monthif(exprOn == DAY_OF_MONTH && expr.indexOf('L') != -1 && expr.length() > 1 && expr.contains(",")) {throw new ParseException("Support for specifying 'L' and 'LW' with other days of the month is not implemented", -1);}// throw an exception if L is used with other days of the weekif(exprOn == DAY_OF_WEEK && expr.indexOf('L') != -1 && expr.length() > 1 && expr.contains(",")) {throw new ParseException("Support for specifying 'L' with other days of the week is not implemented", -1);}if(exprOn == DAY_OF_WEEK && expr.indexOf('#') != -1 && expr.indexOf('#', expr.indexOf('#') +1) != -1) {throw new ParseException("Support for specifying multiple \"nth\" days is not implemented.", -1);}StringTokenizer vTok = new StringTokenizer(expr, ",");while (vTok.hasMoreTokens()) {String v = vTok.nextToken();storeExpressionVals(0, v, exprOn);}exprOn++;}if (exprOn <= DAY_OF_WEEK) {throw new ParseException("Unexpected end of expression.",expression.length());}if (exprOn <= YEAR) {storeExpressionVals(0, "*", YEAR);}TreeSet<Integer> dow = getSet(DAY_OF_WEEK);TreeSet<Integer> dom = getSet(DAY_OF_MONTH);// Copying the logic from the UnsupportedOperationException belowboolean dayOfMSpec = !dom.contains(NO_SPEC);boolean dayOfWSpec = !dow.contains(NO_SPEC);if (!dayOfMSpec || dayOfWSpec) {if (!dayOfWSpec || dayOfMSpec) {throw new ParseException("Support for specifying both a day-of-week AND a day-of-month parameter is not implemented.", 0); }}} catch (ParseException pe) {throw pe;} catch (Exception e) {throw new ParseException("Illegal cron expression format ("+ e.toString() + ")", 0);}}CronExpression 部分代码1)Cron表达式的格式:秒分时⽇⽉周年(可选)。
Quartz Cron 表达式(时间格式的写法)
Quartz cron 表达式的格式十分类似于 UNIX cron 格式,但还是有少许明显的区别。
区别之一就是 Quartz 的格式向下支持到秒级别的计划,而 UNIX cron 计划仅支持至分钟级。
许多我们的触发计划要基于秒级递增的(例如,每45秒),因此这是一个非常好的差异。
在 UNIX cron 里,要执行的作业(或者说命令)是存放在 cron 表达式中的,在第六个域位置上。
Quartz 用 cron 表达式存放执行计划。
引用了 cron 表达式的 CronTrigger 在计划的时间里会与job 关联上。
另一个与UNIX cron 表达式的不同点是在表达式中支持域的数目。
UNIX 给出五个域(分、时、日、月和周),Quartz 提供七个域。
表 5.1 列出了 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, -* /
月份和星期的名称是不区分大小写的。
FRI 和 fri 是一样的。
域之间有空格分隔,这和 UNIX cron 一样。
无可争辩的,我们能写的最简单的表达式看起来就是这个了:
* * * ? * *
这个表达会每秒钟(每分种的、每小时的、每天的)激发一个部署的 job。
?理解特殊字符
同 UNIX cron 一样,Quartz cron 表达式支持用特殊字符来创建更为复杂的执行计划。
然而,Quartz 在特殊字符的支持上比标准 UNIX cron 表达式更丰富了。
* 星号
使用星号(*) 指示着你想在这个域上包含所有合法的值。
例如,在月份域上使用星号意味着每个月都会触发这个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。