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 {

    @Override
    public void execute(JobExecutionContext context)
              throws JobExecutionException {

    }

}

 

在Quartz中:

如果實現org.quartz.Job接口,那么這個job是stateless的,job實例的參數不能在多個任務之間共享

如果實現org.quartz.StatefulJob,這個job是個單例的,job實例的屬性可以從當前任務傳遞到下一個任務。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM