springboot整合 xxl-job及使用步驟
一、xxl-job是什么
XXL-JOB 是一個(gè)分布式任務(wù)調(diào)度平臺,主要用于解決在分布式系統(tǒng)中任務(wù)調(diào)度和任務(wù)管理的問題。
- XXL-JOB 的架構(gòu)通常包括以下幾個(gè)組件:
調(diào)度中心(Scheduler):負(fù)責(zé)任務(wù)的調(diào)度、管理和監(jiān)控,是整個(gè)調(diào)度系統(tǒng)的核心。 - 執(zhí)行器(Executor):負(fù)責(zé)具體任務(wù)的執(zhí)行,可以部署在不同的節(jié)點(diǎn)上。
- Web 管理控制臺:提供友好的 Web 界面,方便用戶進(jìn)行任務(wù)的管理和監(jiān)控。
二、使用步驟
1. 下載并運(yùn)行管理端代碼
項(xiàng)目地址:
1:【gitee】https://gitee.com/xuxueli0323/xxl-job
2:【github】https://github.com/xuxueli/xxl-job
管理端需要注意的地方
執(zhí)行sql腳本,tables_xxl_job.sql
修改application.properties配置文件,主要修改兩處
數(shù)據(jù)庫地址對應(yīng)的是第一步執(zhí)行腳本創(chuàng)建的庫的位置
xxl-job, datasource
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/xxl_job?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai
spring.datasource.username=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
accessToken的值需要和執(zhí)行器中配置的值(后面會(huì)寫)一致
xxl-job, access token
xxl.job.accessToken=default_token
通過Application運(yùn)行程序,也可以打包后通過jar命令啟動(dòng)
2. 訪問管理頁面,確認(rèn)是否啟動(dòng)成功
地址:http://127.0.0.1:8080/xxl-job-admin 【和配置文件一致】
默認(rèn)賬密:admin/123456【忘記密碼可以去數(shù)據(jù)庫修改,使用md5加密后填充】
3. 配置執(zhí)行器【在自己的springboot項(xiàng)目中配置】
引入依賴
<dependency> <groupId>com.xuxueli</groupId> <artifactId>xxl-job-core</artifactId> <version>2.4.0</version> </dependency>
添加配置文件
- accessToken與前面配置一致,address對應(yīng)管理端訪問地址
- executor(執(zhí)行器)的配置與后面在頁面上創(chuàng)建執(zhí)行器時(shí)保持一致
xxl-job admin address list, such as “http://address” or “http://address01,http://address02”
xxl:
job:
accessToken: default_token
admin:
addresses: http://127.0.0.1:8080/xxl-job-admin
executor:
appname: xxl-job-executor-test-zhu
address: http://localhost:9999 # 填充地址,假設(shè)執(zhí)行器運(yùn)行在本地
ip: 127.0.0.1 # 填充本地IP,確保它與address配置一致
port: 9999
logpath: /data/applogs/xxl-job/jobhandler
logretentiondays: -1
執(zhí)行器組件配置
package com.zhui.yudada.config; import com.xxl.job.core.executor.impl.XxlJobSpringExecutor; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Slf4j @Configuration public class XxlJobConfig { @Value(“x x l . j o b . a d m i n . a d d r e s s e s " ) p r i v a t e S t r i n g a d m i n A d d r e s s e s ; @ V a l u e ( " {xxl.job.admin.addresses}") private String adminAddresses; @Value("xxl.job.admin.addresses")privateStringadminAddresses;@Value("{xxl.job.accessToken}”) private String accessToken; @Value(“x x l . j o b . e x e c u t o r . a p p n a m e " ) p r i v a t e S t r i n g a p p n a m e ; @ V a l u e ( " {xxl.job.executor.appname}") private String appname; @Value("xxl.job.executor.appname")privateStringappname;@Value("{xxl.job.executor.address}”) private String address; @Value(“x x l . j o b . e x e c u t o r . i p " ) p r i v a t e S t r i n g i p ; @ V a l u e ( " {xxl.job.executor.ip}") private String ip; @Value("xxl.job.executor.ip")privateStringip;@Value("{xxl.job.executor.port}”) private int port; @Value(“x x l . j o b . e x e c u t o r . l o g p a t h " ) p r i v a t e S t r i n g l o g P a t h ; @ V a l u e ( " {xxl.job.executor.logpath}") private String logPath; @Value("xxl.job.executor.logpath")privateStringlogPath;@Value("{xxl.job.executor.logretentiondays}”) private int logRetentionDays; @Bean public XxlJobSpringExecutor xxlJobExecutor() { log.info(“>>>>>>>>>>> start xxl-job config init”); XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor(); xxlJobSpringExecutor.setAdminAddresses(adminAddresses); xxlJobSpringExecutor.setAppname(appname); xxlJobSpringExecutor.setAddress(address); xxlJobSpringExecutor.setIp(ip); xxlJobSpringExecutor.setPort(port); xxlJobSpringExecutor.setAccessToken(accessToken); xxlJobSpringExecutor.setLogPath(logPath); xxlJobSpringExecutor.setLogRetentionDays(logRetentionDays); return xxlJobSpringExecutor; } }
jobhander配置
package com.zhui.yudada.job; import com.xxl.job.core.biz.model.ReturnT; import com.xxl.job.core.handler.annotation.XxlJob; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; @Component public class HelloJob { @Value("${server.port}") private String port; @XxlJob("demoJobHandler") public ReturnT helloJob() { System.out.println("簡單任務(wù)執(zhí)行了。。。" + port); return ReturnT.SUCCESS; } }
啟動(dòng)項(xiàng)目,出現(xiàn)下面的提示說明啟動(dòng)成功
4. 在頁面上創(chuàng)建執(zhí)行器和任務(wù),與項(xiàng)目中綁定 創(chuàng)建執(zhí)行器【取值與springboot項(xiàng)目中配置文件一一對應(yīng)】
創(chuàng)建任務(wù)
啟動(dòng),驗(yàn)證是否執(zhí)行成功
啟動(dòng)后查看調(diào)度日志,或者觀察程序控制臺數(shù)據(jù)
總結(jié)
如果啟動(dòng)失敗,檢查配置文件的值是否一致,如accessToken的值
參考 https://developer.aliyun.com/article/1436105https://blog.csdn.net/m0_52985087/article/details/135646151
到此這篇關(guān)于springboot整合 xxl-job及使用步驟的文章就介紹到這了,更多相關(guān)springboot整合 xxl-job內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- springboot整合 xxl-job的項(xiàng)目實(shí)踐
- SpringBoot集成xxl-job實(shí)現(xiàn)超牛的定時(shí)任務(wù)的步驟詳解
- springboot整合xxl-job的實(shí)現(xiàn)示例
- xxl-job的部署及springboot集成使用示例詳解
- SpringBoot部署xxl-job方法詳細(xì)講解
- springboot整合xxl-job實(shí)現(xiàn)分布式定時(shí)任務(wù)的過程
- springboot整合xxl-job的示例代碼
- SpringBoot整合Xxl-job實(shí)現(xiàn)定時(shí)任務(wù)的全過程
- Springboot整合xxl-job實(shí)現(xiàn)動(dòng)態(tài)傳參
相關(guān)文章
mybatis?resultMap之collection聚集兩種實(shí)現(xiàn)方式
本文主要介紹了mybatis?resultMap之collection聚集兩種實(shí)現(xiàn)方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-09-09Java中dubbo+zookeeper微服務(wù)架構(gòu)簡介
Apache Dubbo是一款高性能的 Java RPC 框架,這篇文章主要介紹了Java中dubbo+zookeeper微服務(wù)架構(gòu),需要的朋友可以參考下2021-09-09java String[]字符串?dāng)?shù)組自動(dòng)排序的簡單實(shí)現(xiàn)
下面小編就為大家?guī)硪黄猨ava String[]字符串?dāng)?shù)組自動(dòng)排序的簡單實(shí)現(xiàn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09Java中MyBatis傳入?yún)?shù)parameterType問題
這篇文章主要介紹了Java中MyBatis傳入?yún)?shù)parameterType問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12WebSocket實(shí)現(xiàn)聊天室業(yè)務(wù)
這篇文章主要為大家詳細(xì)介紹了WebSocket實(shí)現(xiàn)聊天室業(yè)務(wù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08Java下變量大小寫駝峰、大小寫下劃線、大小寫連線轉(zhuǎn)換
有時(shí)候需要處理對象屬性的getter、setter方法,或者將屬性與數(shù)據(jù)表字段進(jìn)行相互轉(zhuǎn)換,感興趣的可以了解一下2021-06-06