如何搭建基于SpringTask實現(xiàn)動態(tài)管理任務

這篇文章主要講解了“如何搭建基于Spring Task實現(xiàn)動態(tài)管理任務”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何搭建基于Spring Task實現(xiàn)動態(tài)管理任務”吧!

專注于為中小企業(yè)提供成都網站建設、成都網站設計服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)樂陵免費做網站提供優(yōu)質的服務。我們立足成都,凝聚了一批互聯(lián)網行業(yè)人才,有力地推動了上千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網站建設實現(xiàn)規(guī)模擴充和轉變。

什么是定時任務

定時任務是指調度程序在指定的時間或周期觸發(fā)執(zhí)行的任務,常用場景如下:

  • 定時發(fā)短信

  • 定時變更數據

  • 定時統(tǒng)計數據

  • 定時修改狀態(tài)

  • 定時開始活動等

常見幾種JAVA實現(xiàn)方式

Timer

簡介:Timer 是 Jdk自帶的定時任務執(zhí)行類,無論任何項目都可以直接使用 Timer 來實現(xiàn)定時任務,所以 Timer 的優(yōu)點就是使用方便。

原理:

  • 調度器:單線程。

  • 任務存儲:最小堆實現(xiàn)任務存儲。

優(yōu)點:Jdk自帶類,無需引入其他Jar,簡單易用。

缺點:Timer中的多個任務只能使用一個線程去執(zhí)行,因此任務之間的執(zhí)行情況會相互影響。

  • 當一個任務的執(zhí)行時間過長時,會影響其他任務的調度任務異常影響其他任務。

  • 當一個任務拋出異常,其他任務也會終止運行.

結論:基本無人使用。

ScheduledExecutorService

簡介:ScheduledExecutorService  是JDK里面自定義的幾種線程池中的一種,支持多線程并發(fā)的去執(zhí)行多個調度任務,彌補了Timer的缺陷。

原理:

  • 調度器:多線程。

  • 任務存儲:最小堆實現(xiàn)任務存儲。

優(yōu)點:Timer能做到的事情ScheduledExecutorService都能做到,且完美的解決上面所說的Timer存在的兩個問題。

缺點:只支持固定速率(fixed-rate)或固定延遲(fixed-delay)的調度任務,不靈活。

結論:常用于框架內部定時任務。

Spring Task

描述:Spring Framework 自帶的定時任務。

優(yōu)點:同ScheduledExecutorService,同時增加了支持cron表達式,可以配置任意基于時鐘的調度任務。

缺點:

  • 不支持動態(tài)修改任務狀態(tài)、暫停/恢復任務,以及終止運行中任務。

  • 不支持在線監(jiān)控執(zhí)行的任務。

原理:ScheduledExecutorService的擴展。

結論:常用于中小型企業(yè),作為單機定時任務使用。

以上都是單機版本。

其他分布式定時任務諸如:quartz、xxl-job、elastic-job等等,功能、性能都很強勁,這里不作為研究對象,詳情參考:

  • Java定時任務框架對比

  • 定時任務實現(xiàn)原理 最小堆 時間輪

上面的這些框架都不是我想選擇的,要想自由的掌控雷電,那就自己造個簡易輪子,滿足90%需求即可。

期望實現(xiàn)如下特性:

  • 輕量、輕量、輕量。

  • 支持在線監(jiān)控執(zhí)行的任務。

  • 支持動態(tài)修改任務狀態(tài)、暫停/恢復任務,以及終止運行中任務。

  • 支持在線配置調度任務入參和。

  • 支持集群環(huán)境擴展(可選)。

收集了半天信息,直接使用Spring Task就可以實現(xiàn),僅依賴Spring Boot。

Spring Task詳解

初級靜態(tài)配置任務

代碼示例:

@Component  @EnableScheduling // 開啟定時任務 public class DemoApplication {  // 添加定時任務     @Scheduled(cron = "0/5 * * * * *") // cron 表達式,每5秒執(zhí)行     public void doTask(){         System.out.println("我是定時任務~");     } }

無法動態(tài)修改任務狀態(tài)、暫停/恢復任務,以及終止運行中任務。

進階動態(tài)配置任務

實現(xiàn)設計

關鍵技術點和坑

  • Spring  Task的調度器默認是線程數為1的ThreadPoolTaskScheduler,自動裝配類為TaskSchedulingAutoConfiguration,多任務之間的執(zhí)行會相互影響,一定要修改默認值。

  • 通過TaskScheduler接口,可以擴展實現(xiàn)動態(tài)修改任務狀態(tài)、暫停/恢復任務,以及終止運行中任務。

    • TaskScheuler是在Spring  3.0中引入的,有多種方法可以在將來的某個時刻運行,它還返回ScheduledFuture接口的對象,可用于取消計劃的任務或檢查任務是否完成。

  • cron-utils一個Java庫,用于解析,驗證Cron表達式,可以去GitHub查看詳細說明。

實現(xiàn)設計

定義IJob接口,用于客戶端描述任務

public interface IJob {     void execute(JobContext map) throws JobException; }

定義注解,用于配合IJob接口定義任務

@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Component public @interface Job {      @AliasFor(annotation = Component.class)     String value() default "";      /**      * cron 表達式默認不"-"代表不執(zhí)行      */     String cron() default "-";      /**      * 任務編碼 必須唯一      */     String taskCode();      /**      * 任務名稱      */     String taskName();  }

定義運行任務狀態(tài)

public class Task{     /**      * 任務的編碼 必須全局唯一      */     private String taskCode;     /**      * 任務的名稱      */     private String taskName;     /**      * 任務的類名稱      */     private String taskClassName;     /**      * 任務的cron表達式      */     private String taskCron;      @JsonIgnore     private ScheduledFuture scheduledFuture;      @JsonIgnore     private IJob job;      private TaskStateEnum taskState;

定義任務存儲接口,用于存儲在緩存或者DB中

public interface ITaskStore {      void saveTask(Task task);      List<Task> list();      Task updateTaskByTaskCode(String taskCron, String taskName, String taskCode);      Task updateTaskStateByTaskCode(TaskStateEnum taskState, String taskCode);      void deleteTaskByTaskCode(String taskCode);      Task findByTaskCode(String taskCode);  }

定義任務鎖接口,解決并發(fā)問題,以及擴展支持集群環(huán)境

public interface ILockService {     void lock(String taskCode);     void unlock(String taskCode); }

定義事件監(jiān)聽器,用于監(jiān)聽任務的狀態(tài)事件,可擴展狀態(tài)監(jiān)控,各種回調等

public interface IEventListener {     void listener(Event event); }

核心處理器,處理核心流程

  • 初始化加載所有IJob的實現(xiàn) 從Spring容器獲取IJob實現(xiàn)類并解析Job注解

  • 添加任務threadPoolTaskScheduler.schedule(task,cron)

  • 更新任務詳情

    • scheduledFuture.cancel(true)

    • threadPoolTaskScheduler.schedule(task,cron)

  • 啟動任務 threadPoolTaskScheduler.schedule(task,cron)

  • 暫停任務 scheduledFuture.cancel(true)

  • 任務監(jiān)控 TaskList

待實現(xiàn)功能

  • 重試補償:失敗重試。

  • failstore : 存儲失敗任務,供人肉補償。

  • misfire:存儲錯過的任務,供人肉補償。

自己在核心處理器中加下相應的增強功能邏輯即可。

使用示例

直接實現(xiàn)IJob接口并加上Job注解即可

@Job(taskCode = "job1", taskName = "laker測試任務",cron = "0/5 * * * * *") @Slf4j public class TestJob implements IJob {     @Override     public void execute(Map map) throws Exception {         log.info("laker job run");         TimeUnit.SECONDS.sleep(10);     } }

感謝各位的閱讀,以上就是“如何搭建基于Spring Task實現(xiàn)動態(tài)管理任務”的內容了,經過本文的學習后,相信大家對如何搭建基于Spring Task實現(xiàn)動態(tài)管理任務這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!

網站標題:如何搭建基于SpringTask實現(xiàn)動態(tài)管理任務
文章URL:http://muchs.cn/article24/ghiice.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供做網站、網站改版、微信公眾號、域名注冊、外貿建站、

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都app開發(fā)公司