Quartz(任务调度)- job串行避免死锁
生活随笔
收集整理的這篇文章主要介紹了
Quartz(任务调度)- job串行避免死锁
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
參照:http://blog.csdn.net/haitaofeiyang/article/details/50737644
quartz框架中防止任務并行可以有兩種方案:
1、如果是通過MethodInvokingJobDetailFactoryBean在運行中動態生成的Job,配置的xml文件有個concurrent屬性,這個屬性的功能是配置此job是否可以并行運行,如果為false則表示不可以并行運行,否則可以并行。如果一個job的業務處理發費的時間超過了job的啟動的間隔時間(repeatInterval),這個屬性非常有用。如果為false,那么,在這種情況下,當前job還在運行,那么下一個job只能延時運行。如果為true,那么job就會并行運行。 <bean id=" jobCompareB2cAndLocal" class="com.vipshop.management.util.quartz.MethodInvokingJobDetailFactoryBean "><property name="targetObject " ref="delegateJob " /><property name="targetMethod " value="方法名" /><property name="concurrent " value="false "></property > </bean > 2、如果是通過自定義要執行的任務的類的名稱實現job的話,則有另一種方式: 默認的任務的類實現org.quartz.Job接口,此時任務是stateless(無狀態的),即會出現并行的情況,那么如何避免這種情況發生呢? 解決方案:使QuartzJobBean類實現org.quartz.StatefulJob接口即可(StatefulJob接口僅僅是擴展了 Job 接口,未加入新的方法,可以不需實現Job接口了),那么此時任務就會變成stateful(有狀態的),此時的任務也就會串行執行了。 public class BackCoupon implements StatefulJob {@Overridepublic void execute(JobExecutionContext context)throws JobExecutionException {}}?
在Quartz中:
如果實現org.quartz.Job接口,那么這個job是stateless的,job實例的參數不能在多個任務之間共享
如果實現org.quartz.StatefulJob,這個job是個單例的,job實例的屬性可以從當前任務傳遞到下一個任務。
?
轉載于:https://www.cnblogs.com/peak-c/p/5418096.html
總結
以上是生活随笔為你收集整理的Quartz(任务调度)- job串行避免死锁的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Python 关于bytes类方法对数字
- 下一篇: 内部类可以引用它的包含类的成员吗?有没有