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
quartz.properties設定<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; } }
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 *