Quartz與Spring集成的兩種方法示例
Quartz與Spring集成方式:
1.MethodInvokeJobDetailFactoryBean
2.JobDetailBean
下面分別介紹這兩種方式。
1.MethodInvokeJobDetailFactoryBean
1)創(chuàng)建一個Job類,此類不需要實現(xiàn)任何接口,不需要繼承任何類
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í)行的方法,這個參數(shù)是必須的 --> <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> <!-- 設置調(diào)度 --> <bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean"> <property name="triggers"> <ref bean="cronTaskTrigger" /> </property> </bean>
2.JobDetailBean
1)需要繼承QuartzJobBean類或者實現(xiàn)Job方法
public class MyJobBeanTest extends QuartzJobBean { @Override protected void executeInternal(JobExecutionContext context) throws JobExecutionException { System.out.println("測試Quartz:Hello Quartz"); } }
2)配置XML
<!-- 第二種配置方式,需要繼承QuartzJobBean --> <!-- jobClass關聯(lián)到一個繼承自QuartzJobBean的類,它實現(xiàn)了Quartz作業(yè)接口。調(diào)用到這個作業(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' 那么容器啟動就會指定調(diào)度程序 --> <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è)務邏輯簡單,一目了然,缺點是無法持久化。
從我使用的經(jīng)驗來說,我更推薦的第二種,其中一個很重要的原因就是因為定時任務中注入相關Service的時候,后者可以直接注入,而前者還需要進行Scheduler的替換修改。
以上就是Quartz與Spring集成的兩種方法示例的詳細內(nèi)容,更多關于Quartz與Spring集成方法的資料請關注腳本之家其它相關文章!
- 淺談SpringBoot集成Quartz動態(tài)定時任務
- SpringBoot與Quartz集成實現(xiàn)分布式定時任務集群的代碼實例
- SpringBoot集成Quartz實現(xiàn)定時任務的方法
- Spring集成Quartz的簡單配置的方法
- 詳解Quartz 與 Spring框架集成的三種方式
- Spring Boot集成Quartz注入Spring管理的類的方法
- SpringBoot集成quartz實現(xiàn)定時任務詳解
- SpringBoot2.6.3集成quartz的方式
- springBoot項目集成quartz開發(fā)定時任務案例及注意事項
- 可視化定時任務quartz集成解析全過程
相關文章
Java如何將任意類型的Object對象轉(zhuǎn)換為相應的實體對象
這篇文章主要介紹了Java如何將任意類型的Object對象轉(zhuǎn)換為相應的實體對象問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01Java SpringSecurity+JWT實現(xiàn)登錄認證
這篇文章主要介紹了Java SpringSecurity+JWT實現(xiàn)登錄認證,首先通過給需要登錄認證的模塊添加mall-security依賴展開介紹,感興趣的朋友可以參考一下2022-06-06Java輕松掌握面向?qū)ο蟮娜筇匦苑庋b與繼承和多態(tài)
本文主要講述的是面向?qū)ο蟮娜筇匦裕悍庋b,繼承,多態(tài),內(nèi)容含括從封裝到繼承再到多態(tài)的所有重點內(nèi)容以及使用細節(jié)和注意事項,內(nèi)容有點長,請大家耐心看完2022-05-05RabbitMQ中Confirm消息確認機制保障生產(chǎn)端消息的可靠性詳解
這篇文章主要介紹了RabbitMQ中Confirm消息確認機制保障生產(chǎn)端消息的可靠性詳解,生產(chǎn)者將數(shù)據(jù)發(fā)送到 RabbitMQ 的時候,可能數(shù)據(jù)就在半路給搞丟了,因為網(wǎng)絡問題啥的,都有可能,需要的朋友可以參考下2023-12-12關于Java并發(fā)編程中線程間協(xié)作的兩種方式
這篇文章主要介紹了關于Java并發(fā)編程中線程間協(xié)作的兩種方式,當隊列滿時,生產(chǎn)者需要等待隊列有空間才能繼續(xù)往里面放入商品,而在等待的期間內(nèi),生產(chǎn)者必須釋放對臨界資源的占用權,這是消費者模式,需要的朋友可以參考下2023-07-07