1. 程式人生 > >Spring3 + Quartz1.6.2精確的任務排程,並注入service

Spring3 + Quartz1.6.2精確的任務排程,並注入service

Spring採用的是註解的方式注入各種bean,當時可以執行,但是始終拿不到service,最後終於知道了,特此記錄,互相幫助。

下面是Spring配置檔案applicationContext.xml當中的相關配置

<bean id="cronTriggerRefund" class="org.springframework.scheduling.quartz.CronTriggerBean">
	<property name="jobDetail">
		<!-- 使用巢狀Bean的方式來定義任務Bean -->
		<bean class="org.springframework.scheduling.quartz.JobDetailBean">
		<!-- 指定任務Bean的實現類 -->
			<property name="jobClass" value="net.tgx.util.RefundOrderQuzrtz"/>
			<!-- 為任務Bean注入屬性 注意value-ref的值和註解時候對應,key為引用的鍵 -->
			<property name="jobDataAsMap">
				<map>
					<entry key="orderSystemService" value-ref="orderSystemService"/>
				</map>
			</property>
		</bean>
	</property>
	<!-- 指定Cron表示式:每日2時啟動 -->
	<property name="cronExpression" value="0 0 2 * * ?"/>
</bean>

	<bean id="cronTriggerSettle" class="org.springframework.scheduling.quartz.CronTriggerBean">
		<property name="jobDetail">
			<!-- 使用巢狀Bean的方式來定義任務Bean -->
			<bean class="org.springframework.scheduling.quartz.JobDetailBean">
			<!-- 指定任務Bean的實現類 -->
				<property name="jobClass" value="net.tgx.util.SettleQuzrtz"/>
				<!-- 為任務Bean注入屬性 -->
				<property name="jobDataAsMap">
					<map>
						<entry key="orderSystemService" value-ref="orderSystemService"/>
						<entry key="settleService" value-ref="settleService"/>
					</map>
				</property>
			</bean>
		</property>
		<!-- 指定Cron表示式:星期一0時30分啟動 -->
		<property name="cronExpression" value="0 30 0 ? * MON"/>
	</bean>

	<!-- 執行實際的排程排程 -->
<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
	<property name="triggers">
		<list>
			<ref local="cronTriggerRefund"/>
			<ref local="cronTriggerSettle"/>
		</list>
	</property>
</bean>

在對應的實現類裡面的呼叫(PS:這裡只給出一個的例子,兩者都一樣的)

/**   
 * @Title: BusinessReport.java 
 * @Package net.tgx.test 
 * @Description: TODO(用一句話描述該檔案做什麼) 
 * @author Administrator
 * @date 2014-11-18 上午9:46:53 
 * @version V1.0   
 */
package net.tgx.util;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Properties;

import net.tgx.service.IOrderSystemService;
import net.tgx.service.ISettleService;

import org.quartz.Job;
import org.quartz.JobDataMap;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;

/** 
 * @ClassName: BusinessReport 
 * @Description: TODO(這裡用一句話描述這個類的作用) 
 * @author Administrator
 * @date 2014-11-18 上午9:46:53 
 * @version V1.0
 * 
 */
//這裡使用extends QuartzJobBean也是可以的同樣使用
public class SettleQuzrtz implements Job{

	private IOrderSystemService orderSystemService;
	private ISettleService settleService;
		
	/* (非 Javadoc) 
	* <p>Title: execute</p> 
	* <p>Description: </p> 
	* @param arg0
	* @throws JobExecutionException 
	* @see org.quartz.Job#execute(org.quartz.JobExecutionContext) 
	*/
	@Override
	public void execute(JobExecutionContext context) throws JobExecutionException {
		// TODO Auto-generated method stub
<span style="white-space:pre">		</span>//這裡就是獲得配置檔案當中注入的service的方法了
		JobDataMap jobDataMap = context.getJobDetail().getJobDataMap();
	    orderSystemService = (IOrderSystemService)jobDataMap.get("orderSystemService");
	    settleService = (ISettleService) jobDataMap.get("settleService");
		try {
			new SettleOrderTask(orderSystemService, settleService, null, 0.001).run();
		} catch (Exception e) {
			e.printStackTrace();
			return;
		}
	}

	public IOrderSystemService getOrderSystemService() {
		return orderSystemService;
	}

	public void setOrderSystemService(IOrderSystemService orderSystemService) {
		this.orderSystemService = orderSystemService;
	}

	public ISettleService getSettleService() {
		return settleService;
	}

	public void setSettleService(ISettleService settleService) {
		this.settleService = settleService;
	}


	
}
quartz.properties設定
org.quartz.scheduler.instanceName = QuartzScheduler
org.quartz.scheduler.rmi.export = false
org.quartz.scheduler.rmi.proxy = false
org.quartz.scheduler.wrapJobExecutionInUserTransaction = false

org.quartz.threadPool.class = org.quartz.simpl.SimpleThreadPool
org.quartz.threadPool.threadCount = 10
org.quartz.threadPool.threadPriority = 5
org.quartz.threadPool.threadsInheritContextClassLoaderOfInitializingThread = true

org.quartz.jobStore.misfireThreshold = 60000
org.quartz.jobStore.class = org.quartz.simpl.RAMJobStore

關於cron表示式(來自網路):

Cron 表示式包括以下 7 個欄位:

  • 小時
  • 月內日期
  • 周內日期
  • 年(可選欄位)

特殊字元

Cron 觸發器利用一系列特殊字元,如下所示:

  • 反斜線(/)字元表示增量值。例如,在秒欄位中“5/15”代表從第 5 秒開始,每 15 秒一次。

  • 問號(?)字元和字母 L 字元只有在月內日期和周內日期欄位中可用。問號表示這個欄位不包含具體值。所以,如果指定月內日期,可以在周內日期欄位中插入“?”,表示周內日期值無關緊要。字母 L 字元是 last 的縮寫。放在月內日期欄位中,表示安排在當月最後一天執行。在周內日期欄位中,如果“L”單獨存在,就等於“7”,否則代表當月內周內日期的最後一個例項。所以“0L”表示安排在當月的最後一個星期日執行。

  • 在月內日期欄位中的字母(W)字元把執行安排在最靠近指定值的工作日。把“1W”放在月內日期欄位中,表示把執行安排在當月的第一個工作日內。

  • 井號(#)字元為給定月份指定具體的工作日例項。把“MON#2”放在周內日期欄位中,表示把任務安排在當月的第二個星期一。

  • 星號(*)字元是通配字元,表示該欄位可以接受任何可能的值。
欄位 允許值 允許的特殊字元 
秒 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 *