quartz的配置表示式
java服務自帶了定時服務Timer,不過我在研究spring,所以就使用了quartz,因為spring良好的支援了quartz,使用起來還是相當的簡單
- <!-- 實現規則服務實時載入的定時服務配置檔案 -->
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xmlns:tx="http://www.springframework.org/schema/tx"
- xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
- http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd
- http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd">
- <bean id="loadObject" class="com.sunyard.rule.global.ContextLoad"/>
- <bean name="jobDetailBean" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
- <property name="targetObject" ref="loadObject"/>
- <property name="targetMethod" value="load"/>
- </bean>
- <bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
- <property name="jobDetail">
- <ref bean="jobDetailBean" />
- </property>
- <!--
- 下面表示每天晚上21點執行
- 配置具體方法見《定時服務配置說明》
- -->
- <property name="cronExpression">
- <value>0 0 21 * * ?</value>
- </property>
- </bean>
- <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
- <property name="triggers">
- <list>
- <ref bean="cronTrigger" />
- </list>
- </property>
- </bean>
- </beans>
<!-- 實現規則服務實時載入的定時服務配置檔案 -->
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd">
<bean id="loadObject" class="com.sunyard.rule.global.ContextLoad"/>
<bean name="jobDetailBean" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="loadObject"/>
<property name="targetMethod" value="load"/>
</bean>
<bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail">
<ref bean="jobDetailBean" />
</property>
<!--
下面表示每天晚上21點執行
配置具體方法見《定時服務配置說明》
-->
<property name="cronExpression">
<value>0 0 21 * * ?</value>
</property>
</bean>
<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<property name="triggers">
<list>
<ref bean="cronTrigger" />
</list>
</property>
</bean>
</beans>
id="loadObject"是定時服務類;
name="jobDetailBean"用來指定定時服務的方法;
id="cronTrigger"配置定時服務的時間;
最後一個bean用來設定定時服務佇列。
(解釋比較直白)
下面介紹一下定時服務時間的配置,也可以為以後做備忘:
表示式意義:
秒 0-59 , - * /
分 0-59 , - * /
小時 0-23 , - * /
日期 1-31 , - * ? / L W C
月份 1-12 或者 JAN-DEC , - * /
星期 1-7 或者 SUN-SAT , - * ? / L C #
年(可選) 留空, 1970-2099 , - * /
例子:
"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觸發
每天早上6點
0 6 * * *
每兩個小時
0 */2 * * *
晚上11點到早上8點之間每兩個小時,早上八點
0 23-7/2,8 * * *
每個月的4號和每個禮拜的禮拜一到禮拜三的早上11點
0 11 4 * 1-3
1月1日早上4點
0 4 1 1 *
特殊字元說明:
"*"字元被用來指定所有的值。如:"*"在分鐘的欄位域裡表示"每分鐘"。
"?"字元只在日期域和星期域中使用。它被用來指定"非明確的值"。當你需要通過在這兩個域中的一個來指定一些東西的時候,它是有用的。
月份中的日期和星期中的日期這兩個元素時互斥的一起應該通過設定一個問號(?)來表明不想設定那個欄位
"-"字元被用來指定一個範圍。如:"10-12"在小時域意味著"10點、11點、12點"。
","字元被用來指定另外的值。如:"MON,WED,FRI"在星期域裡表示"星期一、星期三、星期五".
"/"字元用來指定具體的增量。如"0/15"在秒中的配置表示"從0秒開始每隔15秒",即"0,15,30,45"。
如"5/15"在秒中的配置表示"從5秒開始每隔15秒",即"5,20,35,50"。"*/5"和"0/5"是一個效果。
L是‘last’的省略寫法可以表示day-of-month和day-of-week域,但在兩個欄位中的意思不同,
例如day-of-month域中表示一個月的最後一天, 如果在day-of-week域表示‘7’或者‘SAT’,
如果在day-of-week域中前面加上數字,它表示一個月的最後幾天,例如‘6L’就表示一個月的最後一個星期五。
The 'W' character is allowed for the day-of-month field. This character is used to specify the weekday (Monday-Friday) nearest the given day. As an example, if you were to specify "15W" as the value for the day-of-month field, the meaning is: "the nearest weekday to the 15th of the month". So if the 15th is a Saturday, the trigger will fire on Friday the 14th. If the 15th is a Sunday, the trigger will fire on Monday the 16th. If the 15th is a Tuesday, then it will fire on Tuesday the 15th. However if you specify "1W" as the value for day-of-month, and the 1st is a Saturday, the trigger will fire on Monday the 3rd, as it will not 'jump' over the boundary of a month's days. The 'W' character can only be specified when the day-of-month is a single day, not a range or list of days
.
The 'L' and 'W' characters can also be combined for the day-of-month expression to yield 'LW', which translates to "last weekday of the month".
The '#' character is allowed for the day-of-week field. This character is used to specify "the nth" XXX day of the month. For example, the value of "6#3" in the day-of-week field means the third Friday of the month (day 6 = Friday and "#3" = the 3rd one in the month). Other examples: "2#1" = the first Monday of the month and "4#5" = the fifth Wednesday of the month. Note that if you specify "#5" and there is not 5 of the given day-of-week in the month, then no firing will occur that month.
The 'C' character is allowed for the day-of-month and day-of-week fields. This character is short-hand for "calendar". This means values are calculated against the associated calendar, if any. If no calendar is associated, then it is equivalent to having an all-inclusive calendar. A value of "5C" in the day-of-month field means "the first day included by the calendar on or after the 5th". A value of "1C" in the day-of-week field means "the first day included by the calendar on or after sunday".
相關文章
- quartz.net 時間表示式----- Cron表示式詳解quartz
- Quartz conTrigger 定時器表示式大全quartz定時器
- java 定時任務 quartz 時間表示式Cron總結Javaquartz
- SpringCloud(第 054 篇)簡單 Quartz-Cluster 微服務,採用註解配置 Quartz 分散式叢集SpringGCCloudquartz微服務分散式
- spring整合quartz的叢集配置例項Springquartz
- C#中的Lambda表示式和表示式樹C#
- [轉]Java 8 的 lambda 表示式 Java 8 的 lambda 表示式Java
- Quartz叢集原理及配置應用quartz
- Quartz - Spring和Quartz的整合quartzSpring
- 表示式
- Java的Lambda表示式Java
- angular中的表示式Angular
- SQLite中的表示式SQLite
- cpp的lambda表示式
- python--表示式(運算表示式)Python
- 【JavaEE】JSP表示式--EL表示式用法JavaJS
- 【正規表示式】常用的正規表示式(數字,漢字,字串,金額等的正規表示式)字串
- Quartz定時任務框架(三)SimpleTrigger和CronTrigger、最詳細的Cron表示式範例quartz框架
- Spring Boot 配置 Quartz 定時任務Spring Bootquartz
- boost 正規表示式解析配置檔案或命令列命令列
- C# Lambda表示式詳解,及Lambda表示式樹的建立C#
- 中綴表示式轉為逆波蘭表示式
- 【c#表示式樹】最完善的表示式樹Expression.Dynamic的玩法C#Express
- JavaScript 表示式JavaScript
- JavaScript表示式JavaScript
- lambda 表示式
- cron表示式
- 表示式樹
- lambda表示式
- Lambda 表示式的應用
- Java 中的 Lambda 表示式Java
- JavaScript的正規表示式JavaScript
- JS 的正規表示式JS
- Scala的for表示式進階
- 表示素數的函式函式
- .NET 中的表示式樹
- 任務排程 Quartz 儘量做到可配置?quartz
- 函式宣告和函式表示式的區別函式