Quartz與Spring集成的兩種方法示例
Quartz與Spring集成方式:
1.MethodInvokeJobDetailFactoryBean
2.JobDetailBean
下面分別介紹這兩種方式。
1.MethodInvokeJobDetailFactoryBean
1)創(chuàng)建一個Job類,此類不需要實現任何接口,不需要繼承任何類
public class MyJobTest { public void execute(){ System.out.println("正在執(zhí)行quartz任務的一個方法。。。"); } }
2)配置XML
<!-- 第一種集成方式:MethodInvokingJobDetailFactoryBean,并且job類,直接是pojo類,與普通類沒有區(qū)別 --> <!-- 定義具體的任務類 --> <bean id="myJob" class="com.high.quartz.MyJobTest" /> <!-- 定義JobDetail --> <bean id="jobDetail" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean"> <!-- 目標類 --> <property name="targetObject" ref="myJob" /> <!-- 目標類中要執(zhí)行的方法,這個參數是必須的 --> <property name="targetMethod" value="execute" /> </bean> <!-- 定義simpleTrigger觸發(fā)器 --> <bean id="simpleTaskTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerFactoryBean"> <!-- 延遲10秒啟動,然后每隔3秒執(zhí)行一次,一共執(zhí)行8次 --> <property name="jobDetail" ref="jobDetail" /> <property name="repeatCount" value="8" /> <property name="startDelay" value="10000" /> <property name="repeatInterval" value="3000" /> </bean> <!-- 定義cronTrigger觸發(fā)器 --> <bean id="cronTaskTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean"> <property name="jobDetail" ref="jobDetail" /> <!-- 下午4點25分開始,每5秒執(zhí)行一次 --> <property name="cronExpression" value="0/5 25 16 ? * *" /> </bean> <!-- 設置調度 --> <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> <property name="triggers"> <ref bean="cronTaskTrigger" /> </property> </bean>
2.JobDetailBean
1)需要繼承QuartzJobBean類或者實現Job方法
public class MyJobBeanTest extends QuartzJobBean { @Override protected void executeInternal(JobExecutionContext context) throws JobExecutionException { System.out.println("測試Quartz:Hello Quartz"); } }
2)配置XML
<!-- 第二種配置方式,需要繼承QuartzJobBean --> <!-- jobClass關聯到一個繼承自QuartzJobBean的類,它實現了Quartz作業(yè)接口。調用到這個作業(yè)的時候,它的executeInternal將被執(zhí)行。--> <bean id="jobDetail" class="org.springframework.scheduling.quartz.JobDetailFactoryBean"> <property name="jobClass" value="com.high.quartz.MyJobBeanTest" /> <property name="durability" value="true" /> </bean> <bean id="simpleTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerFactoryBean"> <property name="jobDetail" ref="jobDetail" /> <property name="startDelay" value="3000" /> <property name="repeatInterval" value="2000" /> </bean> <bean id="cronTrigger" class="org.springframework.scheduling.quartz.CronTriggerFactoryBean"> <property name="jobDetail" ref="jobDetail" /> <property name="cronExpression" value="0/5 46 16 ? * *" /> </bean> <!-- 總管理類,如果lazy-init='false' 那么容器啟動就會指定調度程序 --> <bean id="startQuartz" lazy-init="false" autowire="no" class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> <!-- 管理trigger --> <property name="triggers"> <list> <ref bean="cronTrigger" /> </list> </property> </bean>
3.兩種集成方式的簡單說明
1)使用MethodInvokeJobDetailFactoryBean則需要指定targetObject(任務實例)和targetMethod(實例中要執(zhí)行的方法)
2)使用QuartzJobBean,需要繼承。
前者優(yōu)點是無侵入,業(yè)務邏輯簡單,一目了然,缺點是無法持久化。
從我使用的經驗來說,我更推薦的第二種,其中一個很重要的原因就是因為定時任務中注入相關Service的時候,后者可以直接注入,而前者還需要進行Scheduler的替換修改。
以上就是Quartz與Spring集成的兩種方法示例的詳細內容,更多關于Quartz與Spring集成方法的資料請關注腳本之家其它相關文章!
相關文章
Java如何將任意類型的Object對象轉換為相應的實體對象
這篇文章主要介紹了Java如何將任意類型的Object對象轉換為相應的實體對象問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01Java輕松掌握面向對象的三大特性封裝與繼承和多態(tài)
本文主要講述的是面向對象的三大特性:封裝,繼承,多態(tài),內容含括從封裝到繼承再到多態(tài)的所有重點內容以及使用細節(jié)和注意事項,內容有點長,請大家耐心看完2022-05-05RabbitMQ中Confirm消息確認機制保障生產端消息的可靠性詳解
這篇文章主要介紹了RabbitMQ中Confirm消息確認機制保障生產端消息的可靠性詳解,生產者將數據發(fā)送到 RabbitMQ 的時候,可能數據就在半路給搞丟了,因為網絡問題啥的,都有可能,需要的朋友可以參考下2023-12-12