<!--作業調度 -->
<
bean
name
=
"taskJob"
class
=
"cn.infohow.kpi.wfmanager.job.service.impl.JobScannerImpl"
/>
<
bean
id
=
"methodInvokingJobDetail"
class
=
"org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"
>
<
property
name
=
"targetObject"
>
<
ref
bean
=
"taskJob"
/>
</
property
>
<
property
name
=
"targetMethod"
>
<
value
>execute</
value
>
</
property
>
</
bean
>
<!-- 配置觸發器 -->
<
bean
id
=
"cronTrigger"
class
=
"org.springframework.scheduling.quartz.CronTriggerBean"
>
<!-- 這裏不可以直接在屬性jobDetail中引用taskJob,因爲他要求的是一個jobDetail類型的對象,所以我們得通過MethodInvokingJobDetailFactoryBean來轉一下 -->
<
property
name
=
"jobDetail"
>
<
ref
bean
=
"methodInvokingJobDetail"
/>
</
property
>
<!-- 每天的8點到21點每隔1分鐘觸發,具體說明見附錄 -->
<
property
name
=
"cronExpression"
>
<
value
>0/10 * 08-21 * * ?</
value
>
</
property
>
</
bean
>
<
bean
id
=
"simpleTrigger"
class
=
"org.springframework.scheduling.quartz.SimpleTriggerBean"
>
<!-- 這裏不可以直接在屬性jobDetail中引用taskJob,因爲他要求的是一個jobDetail類型的對象,所以我們得通過MethodInvokingJobDetailFactoryBean來轉一下 -->
<
property
name
=
"jobDetail"
>
<
ref
bean
=
"methodInvokingJobDetail"
/>
</
property
>
<
property
name
=
"startDelay"
value
=
"10000"
/>
<
property
name
=
"repeatInterval"
value
=
"2000"
/>
</
bean
>
<
bean
class
=
"org.springframework.scheduling.quartz.SchedulerFactoryBean"
>
<!-- 添加觸發器 -->
<
property
name
=
"triggers"
>
<
list
>
<
ref
local
=
"cronTrigger"
/>
</
list
>
</
property
>
</
bean
>
CronTrigger基於日曆和時間,SimpleTrigger基於時間。
每天8:32,12:32 執行一次,啓動的時候執行一次;
- <!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>
- <bean id="weekJobDetailFactoryBean" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
- <property name="targetObject" ref="weekTimer" />
- <property name="targetMethod" value="main" />
- <property name="concurrent" value="false" />
- </bean>
- <bean id="weekCronTriggerBean" class="org.springframework.scheduling.quartz.CronTriggerBean">
- <property name="jobDetail" ref="weekJobDetailFactoryBean" />
- <property name="cronExpression">
- <value>0 0/32 8,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-14 11: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時觸發.