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