quartz的配置表示式

醉面韋陀發表於2010-04-07

java服務自帶了定時服務Timer,不過我在研究spring,所以就使用了quartz,因為spring良好的支援了quartz,使用起來還是相當的簡單

Java程式碼 複製程式碼
  1. <!-- 實現規則服務實時載入的定時服務配置檔案 -->   
  2.   
  3. <beans xmlns="http://www.springframework.org/schema/beans"  
  4.          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  5.          xmlns:aop="http://www.springframework.org/schema/aop"  
  6.          xmlns:tx="http://www.springframework.org/schema/tx"  
  7.          xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd   
  8.            http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd   
  9.            http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.0.xsd">   
  10.        
  11.     <bean id="loadObject" class="com.sunyard.rule.global.ContextLoad"/>   
  12.        
  13.     <bean name="jobDetailBean" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">   
  14.         <property name="targetObject" ref="loadObject"/>   
  15.         <property name="targetMethod" value="load"/>   
  16.     </bean>   
  17.        
  18.     <bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">   
  19.        <property name="jobDetail">   
  20.            <ref bean="jobDetailBean" />   
  21.        </property>   
  22.        <!--    
  23.             下面表示每天晚上21點執行   
  24.             配置具體方法見《定時服務配置說明》   
  25.        -->   
  26.        <property name="cronExpression">   
  27.            <value>0 0 21 * * ?</value>   
  28.        </property>   
  29.     </bean>   
  30.        
  31.     <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">   
  32.         <property name="triggers">   
  33.             <list>   
  34.                 <ref bean="cronTrigger" />   
  35.             </list>   
  36.         </property>   
  37.     </bean>   
  38. </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".

相關文章