現網有7個定時任務,其中一個定時任務經常會執行一段時間后停止,重啟多次依然如此,quartz默認線程數為10,使用了@DisallowConcurrentExecution注解,問題依舊。
經觀察,發現出現問題的任務設定的每個小時執行一次,但每次執行時間都很長,一般會有七八個小時,其他正常的任務都在很短的時間內執行完成。懷疑是由於任務執行較長的原因,因此對該任務進行了結構調整
解決方案:
在耗時較長的任務調整為異步執行,job中只是組織數據,放入緩存,由另外一條線程從緩存中獲取數據進行處理,如果另外一條線程還未處理完上一批次的數據,則下次job任務執行時不再向緩存中添加數據。
經過以上處理后,經過觀察,在以往兩三天就會停止的sas任務,沒有再出現過任務不執行的問題。(但具體原因還需要時間查看下quartz底層實現機制)