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

