SimpleTrigger和CronTrigger配置說明和cornExpression表示式
CronTrigger基於日曆和時間,SimpleTrigger基於時間。
每天8:32,12:32 執行一次,啟動的時候執行一次;
Java程式碼- <!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN"
- "http://www.springframework.org/dtd/spring-beans.dtd">
- <beans default-lazy-init="false">
- <bean id="weekTimer"class="com.chanceit.weather.WeatherHarvestListener"
- <bean id="weekJobDetailFactoryBean"class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
- <property name="targetObject" ref="weekTimer" />
- <property name="targetMethod" value="main" />
- <property name="concurrent"
- </bean>
- <bean id="weekCronTriggerBean"class="org.springframework.scheduling.quartz.CronTriggerBean">
- <property name="jobDetail" ref="weekJobDetailFactoryBean" />
- <property name="cronExpression">
- <value>00/328,12 * * ?</value>
- </property>
- </bean>
- <bean id="schedulerFactoryBean"class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
- <property name="triggers">
- <list>
- <ref local="weekCronTriggerBean" />
- <ref local="simpleTrigger" />
- </list>
- </property>
- </bean>
- <bean id="simpleTrigger"class="org.springframework.scheduling.quartz.SimpleTriggerBean">
- <property name="jobDetail">
- <ref bean="weekJobDetailFactoryBean"/>
- </property>
- <property name="startDelay">
- <value>10000</value>
- </property>
- <property name="repeatInterval">
- <value>0</value>
- </property>
- <property name="repeatCount">
- <value>0</value>
- </property>
- </bean>
- </beans>
Quartz 是個開源的作業排程框架,為在 Java 應用程式中進行作業排程提供了簡單卻強大的機制。Quartz 允許開發人員根據時間間隔(或天)來排程作業。它實現了作業和觸發器的多對多關係,還能把多個作業與不同的觸發器關聯。整合了 Quartz 的應用程式可以重用來自不同事件的作業,還可以為一個事件組合多個作業。
SimpleTrigger 當需要在規定的時間執行一次或在規定的時間段以一定的時間間隔重複觸發執行Job時,SimpleTrigger就可以滿足要求;SimpleTrigger的屬性有:開始時間、結束時間、重複次數和重複的時間間隔,重複次數屬性的值可以為0、正整數、或常量 SimpleTrigger.REPEAT_INDEFINITELY,重複的時間間隔屬性值必須為0或長整型的正整數,以毫秒作為時間單位,當重複的時 間間隔為0時,意味著與Trigger同時觸發執行(或幾乎與Scheduler開始時同時觸發執行)。如果有指定結束時間屬性值,則結束時間屬性優先於重複次數屬性,這樣的好處在於:當我們需要建立一個每間隔10秒鐘觸發一次直到指定的結束時間的 Trigger,而無需去計算從開始到結束的所重複的次數,我們只需簡單的指定結束時間和使用REPEAT_INDEFINITELY作為重複次數的屬性 值即可(我們也可以指定一個比在指定結束時間到達時實際執行次數大的重複次數)。
●SimpleTrigger(String name, String group, String jobName, String jobGroup, Date startTime, Date endTime, int repeatCount, long repeatInterval)
配置檔案示例 :
執行2次
<bean id="simpleTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean">
<!--指定觸發器關聯的作業-->
<property name="jobDetail">
<ref bean="weekJobDetailFactoryBean"/>
</property>
<!--延遲10s-->
<property name="startDelay">
<value>10000</value>
</property>
<!--每60s啟動一次-->
<property name="repeatInterval">
<value>60000</value>
</property>
<!--重複一次-->
<property name="repeatCount">
<value>1</value>
</property>
</bean>
執行1次:
<bean id="simpleTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean">
<property name="jobDetail">
<ref bean="weekJobDetailFactoryBean"/>
</property>
<property name="startDelay">
<value>10000</value>
</property>
<property name="repeatInterval">
<value>20000</value>
</property>
<property name="repeatCount"> (去掉可以按結束時間來迴圈,否則執行完後不會在執行了即使endTime時間沒到)
<value>0</value>
</property>
- <property name="startTime">
- <value>2013-08-1411:07:00</value>
- </property>
<property name="endTime" value="2014-06-30 18:22:00" />
</bean>
<bean id="dateEditor" class="org.springframework.beans.propertyeditors.CustomDateEditor">
<constructor-arg>
<bean class="java.text.SimpleDateFormat">
<constructor-arg value="yyyy-MM-dd HH:mm:ss" />
</bean>
</constructor-arg>
<constructor-arg value="true" />
</bean>
<bean class="org.springframework.beans.factory.config.CustomEditorConfigurer">
<property name="customEditors">
<map>
<entry key="java.util.Date">
<ref local="dateEditor" />
</entry>
</map>
</property>
</bean>
CronTrigger 支援比 SimpleTrigger 更具體的排程,而且也不是很複雜。基於 cron 表示式,CronTrigger 支援類似日曆的重複間隔,而不是單一的時間間隔。
Cron 表示式包括以下 7 個欄位:
格式: [秒] [分] [小時] [日] [月] [周] [年]
序號 說明 是否必填 允許填寫的值 允許的萬用字元
1 秒 是 0-59 , - * /
2 分 是 0-59 , - * /
3 小時 是 0-23 , - * /
4 日 是 1-31 , - * ? / L W
5 月 是 1-12 or JAN-DEC , - * /
6 周 是 1-7 or SUN-SAT , - * ? / L #
7 年 否 empty 或 1970-2099 , - * /
萬用字元說明:
1. 反斜線(/)字元表示增量值。例如,在秒欄位中“5/15”代表從第 5 秒開始,每 15 秒一次。
2. 星號(*)字元是通配字元,表示該欄位可以接受任何可能的值(例如:在分的欄位上設定 "*",表示每一分鐘都會觸發)。
3. 問號(?)問號表示這個欄位不包含具體值。所以,如果指定月內日期,可以在月內日期欄位中插入“?”,表示周內日期值無關緊要。字母 L 字元是 last 的縮寫。放在月內日期欄位中,表示安排在當月最後一天執行。在周內日期欄位中,如果“L”單獨存在,就等於“7”,否則代表當月內周內日期的最後一個例項。所以“0L”表示安排在當月的最後一個星期日執行。
4. - 表示區間,例如 在小時上設定 "10-12",表示 10,11,12點都會觸發。
5. 逗號(, ) 表示指定多個值,例如在周欄位上設定 "MON,WED,FRI" 表示週一,週三和週五觸發
6. 井號(#)字元為給定月份指定具體的工作日例項。把“MON#2”放在周內日期欄位中,表示把任務安排在當月的第二個星期一。
7. L 表示最後的意思。在日欄位設定上,表示當月的最後一天(依據當前月份,如果是二月還會依據是否是潤年[leap]), 在周欄位上表示星期六,相當於"7"或"SAT"。如果在"L"前加上數字,則表示該資料的最後一個。例如在周欄位上設定"6L"這樣的格式,則表示“本月最後一個星期五"。
8. W 表示離指定日期的最近那個工作日(週一至週五). 例如在日欄位上設定"15W",表示離每月15號最近的那個工作日觸發。如果15號正好是週六,則找最近的週五(14號)觸發, 如果15號是周未,則找最近的下週一(16號)觸發.如果15號正好在工作日(週一至週五),則就在該天觸發。如果指定格式為 "1W",它則表示每月1號往後最近的工作日觸發。如果1號正是週六,則將在3號下週一觸發。(注,"W"前只能設定具體的數字,不允許區間"-")。
注:'L'和 'W'可以一組合使用。如果在日欄位上設定"LW",則表示在本月的最後一個工作日觸發。
常用示例:
0 10 * * * ?--------------每個小時過10分執行一次
0 0/32 8,12 * * ? ----------每天8:32,12:32 執行一次
0 0/2 * * * ?--------------每2分鐘執行一次
0 0 12 * * ?---------------在每天中午12:00觸發
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:00至2:59之間每分鐘觸發一次
0 0/5 14 * * ?---------------每天在下午2:00至2:59之間每5分鐘觸發一次
0 0/5 14,18 * * ?---------------每天在下午2:00至2:59和6:00至6:59之間的每5分鐘觸發一次
0 0-5 14 * * ?---------------每天在下午2:00至2:05之間每分鐘觸發一次
0 10,44 14 ? 3 WED---------------每三月份的星期三在下午2:00和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, 2003, 2004 and 2005年的每個月的最後一個星期五的上午10:15觸發
0 15 10 ? * 6#3---------------在每個月的第三個星期五的上午10:15觸發
0 0 12 1/5 * ?---------------從每月的第一天起每過5天的中午12:00時觸發
0 11 11 11 11 ?---------------在每個11月11日的上午11:11時觸發.