springboot整合xxl-job實現(xiàn)分布式定時任務的過程
一、前言
定時任務有很多種,有一些大的框架也有一些簡單的實現(xiàn)。
比如常見的:
- JDK的
Timer和TimerTask Quartz異步任務調(diào)度框架- 分布式定時任務
XXL-JOB - Spring Task注解
@Scheduled
小編也就知道這些,歡迎大佬補充哈??!
今天小編就以現(xiàn)在比較火的分布式定時任務xxl-job,優(yōu)點比較輕量級,但是從21年到現(xiàn)在沒有比較大的更新!
現(xiàn)在最新的好像是2.4.0。
二、xxl-job介紹
XXL-JOB是一個分布式任務調(diào)度平臺,其核心設計目標是開發(fā)迅速、學習簡單、輕量級、易擴展?,F(xiàn)已開放源代碼并接入多家公司線上產(chǎn)品線,開箱即用。
它是美團大佬:許雪里開發(fā)出來的!
本篇以實踐教學為主,介紹大家感興趣可以去官方文檔去看看!
總體架構圖:

大家自行拉去最新代碼即可:
三、修改配置
1. 運行sql文件

導出到本地數(shù)據(jù)庫:

XXL-JOB調(diào)度模塊基于自研調(diào)度組件并支持集群部署,調(diào)度數(shù)據(jù)庫表說明如下:
- xxl_job_lock:任務調(diào)度鎖表;
- xxl_job_group:執(zhí)行器信息表,維護任務執(zhí)行器信息;
- xxl_job_info:調(diào)度擴展信息表: 用于保存XXL-JOB調(diào)度任務的擴展信息,如任務分組、任務名、機器地址、執(zhí)行器、執(zhí)行入?yún)⒑蛨缶]件等等;
- xxl_job_log:調(diào)度日志表: 用于保存XXL-JOB任務調(diào)度的歷史信息,如調(diào)度結果、執(zhí)行結果、調(diào)度入?yún)ⅰ⒄{(diào)度機器和執(zhí)行器等等;
- xxl_job_log_report:調(diào)度日志報表:用戶存儲XXL-JOB任務調(diào)度日志的報表,調(diào)度中心報表功能頁面會用到;
- xxl_job_logglue:任務GLUE日志:用于保存GLUE更新歷史,用于支持GLUE的版本回溯功能;
- xxl_job_registry:執(zhí)行器注冊表,維護在線的執(zhí)行器和調(diào)度中心機器地址信息;
- xxl_job_user:系統(tǒng)用戶表;
2. 修改xxl-job-admin配置
小編修改了一下端口號:
server.port=8087
記得調(diào)整成自己的數(shù)據(jù)庫密碼:
spring.datasource.password=root
由于sql文件導入的直接是個數(shù)據(jù)庫,不需要我們在調(diào)整數(shù)據(jù)庫的名稱!
3. 需修改xxl-job-executor-sample-springboot配置
小編這里修改了端口號:
server.port=8086
第11行:修改為admin的端口
xxl.job.admin.addresses=http://127.0.0.1:8087/xxl-job-admin
第22行:小編9999端口被占用,修改了一下端口
xxl.job.executor.port=9998
4. 添加自己的定時任務
@XxlJob("testJobHandler")
public void testJobHandler() throws Exception {
for (int i = 0; i < 5; i++) {
XxlJobHelper.log("這是第" + i + 1 + "條日志!");
System.out.println("這是第" + i + 1 + "次看到我了!");
}
System.out.println("定時任務結束??!");
}
四、運行項目
1. 啟動項目

2. 登錄
根據(jù)上一步的配置,我們直接端口號加服務名字進行訪問:
http://localhost:8087/xxl-job-admin/
賬號:admin
密碼:123456

3. xxl-job的好處
自己寫完的定時任務,可以交給這個管理,這樣什么時候運行,定時任務的執(zhí)行規(guī)則,都可以在可視化的界面進行管理和操作,更加的人性化!可以動態(tài)的修改cron表達式,還有日志執(zhí)行情況,這是真的香?。?!
4. 查看執(zhí)行器獲取網(wǎng)址
默認已經(jīng)把springboot整合上來了,如果大家是自己新建的模塊可以新增一條,讓管理器管理咱們自己項目的定時任務,也就是使用@XxlJob的任務!

5. 新增任務管理
這里比較智能,一些基本的cron表達式都可以幫你寫,非常的人性??!
JobHandler:填@XxlJob里面的名字即可,小編這里是:@XxlJob("testJobHandler"),所以是testJobHandler

6. 執(zhí)行任務
我們這次執(zhí)行一次,看看控制臺是否打印記錄,看看我們寫的任務是否執(zhí)行了??!

任務參數(shù)隨便輸入,機器地址為:http://192.168.1.207:9998/,第4步查看的,也就是管理端的地址加端口??!

7. 執(zhí)行成功
我們看到方法成功被執(zhí)行了!!

8. 查看日志

五、總結
大家看到我的日志還是有執(zhí)行失敗的,原因是開始端口被占用,沒有注意,一直在測試,一直失?。?!
大家運行后一定看看控制臺有沒有報錯,如果是java.net.BindException: Address already in use: bind
那就是端口號被占用,換一個就行了?。?br />也可以看看小編這篇文章,詳細解決了這個問題??!
到此這篇關于springboot整合xxl-job分布式定時任務的文章就介紹到這了,更多相關springboot整合xxl-job定時任務內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Spring連接Mysql數(shù)據(jù)庫的實現(xiàn)步驟
本文主要介紹了Spring連接Mysql數(shù)據(jù)庫的實現(xiàn)步驟,文中根據(jù)實例編碼詳細介紹的十分詳盡,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
java使用MulticastSocket實現(xiàn)基于廣播的多人聊天室
這篇文章主要為大家詳細介紹了java使用MulticastSocket實現(xiàn)基于廣播的多人聊天室,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-01-01

