0


springboot整合 xxl-job

文章目录


一、xxl-job是什么

XXL-JOB 是一个分布式任务调度平台,主要用于解决在分布式系统中任务调度和任务管理的问题。

  1. XXL-JOB 的架构通常包括以下几个组件: 调度中心(Scheduler):负责任务的调度、管理和监控,是整个调度系统的核心。
  2. 执行器(Executor):负责具体任务的执行,可以部署在不同的节点上。
  3. Web 管理控制台:提供友好的 Web 界面,方便用户进行任务的管理和监控。

二、使用步骤

1. 下载并运行管理端代码

项目地址:
1️⃣:【gitee】https://gitee.com/xuxueli0323/xxl-job
2️⃣:【github】https://github.com/xuxueli/xxl-job
项目整体结构
管理端需要注意的地方
在这里插入图片描述

  1. 执行sql脚本,tables_xxl_job.sql
  2. 修改application.properties配置文件,主要修改两处 - 数据库地址对应的是第一步执行脚本创建的库的位置### xxl-job, datasourcespring.datasource.url=jdbc:mysql://127.0.0.1:3306/xxl_job?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghaispring.datasource.username=rootspring.datasource.password=123456spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver- accessToken的值需要和执行器中配置的值(后面会写)一致### xxl-job, access tokenxxl.job.accessToken=default_token
  3. 通过Application运行程序,也可以打包后通过jar命令启动

2. 访问管理页面,确认是否启动成功

地址:http://127.0.0.1:8080/xxl-job-admin 【和配置文件一致】
默认账密:admin/123456【忘记密码可以去数据库修改,使用md5加密后填充】

3. 配置执行器【在自己的springboot项目中配置】

  1. 引入依赖
  1. <dependency>
  2. <groupId>com.xuxueli</groupId>
  3. <artifactId>xxl-job-core</artifactId>
  4. <version>2.4.0</version>
  5. </dependency>
  1. 添加配置文件
  • accessToken与前面配置一致,address对应管理端访问地址
  • executor(执行器)的配置与后面在页面上创建执行器时保持一致
  1. ### xxl-job admin address list, such as "http://address" or "http://address01,http://address02"
  2. xxl:
  3. job:
  4. accessToken: default_token
  5. admin:
  6. addresses: http://127.0.0.1:8080/xxl-job-admin
  7. executor:
  8. appname: xxl-job-executor-test-zhu
  9. address: http://localhost:9999 # 填充地址,假设执行器运行在本地
  10. ip: 127.0.0.1 # 填充本地IP,确保它与address配置一致
  11. port: 9999
  12. logpath: /data/applogs/xxl-job/jobhandler
  13. logretentiondays: -1
  1. 执行器组件配置
  1. package com.zhui.yudada.config;
  2. import com.xxl.job.core.executor.impl.XxlJobSpringExecutor;
  3. import lombok.extern.slf4j.Slf4j;
  4. import org.springframework.beans.factory.annotation.Value;
  5. import org.springframework.context.annotation.Bean;
  6. import org.springframework.context.annotation.Configuration;
  7. @Slf4j
  8. @Configuration
  9. public class XxlJobConfig {
  10. @Value("${xxl.job.admin.addresses}")
  11. private String adminAddresses;
  12. @Value("${xxl.job.accessToken}")
  13. private String accessToken;
  14. @Value("${xxl.job.executor.appname}")
  15. private String appname;
  16. @Value("${xxl.job.executor.address}")
  17. private String address;
  18. @Value("${xxl.job.executor.ip}")
  19. private String ip;
  20. @Value("${xxl.job.executor.port}")
  21. private int port;
  22. @Value("${xxl.job.executor.logpath}")
  23. private String logPath;
  24. @Value("${xxl.job.executor.logretentiondays}")
  25. private int logRetentionDays;
  26. @Bean
  27. public XxlJobSpringExecutor xxlJobExecutor() {
  28. log.info(">>>>>>>>>>> start xxl-job config init");
  29. XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();
  30. xxlJobSpringExecutor.setAdminAddresses(adminAddresses);
  31. xxlJobSpringExecutor.setAppname(appname);
  32. xxlJobSpringExecutor.setAddress(address);
  33. xxlJobSpringExecutor.setIp(ip);
  34. xxlJobSpringExecutor.setPort(port);
  35. xxlJobSpringExecutor.setAccessToken(accessToken);
  36. xxlJobSpringExecutor.setLogPath(logPath);
  37. xxlJobSpringExecutor.setLogRetentionDays(logRetentionDays);
  38. return xxlJobSpringExecutor;
  39. }
  40. }
  1. jobhander配置
  1. package com.zhui.yudada.job;
  2. import com.xxl.job.core.biz.model.ReturnT;
  3. import com.xxl.job.core.handler.annotation.XxlJob;
  4. import org.springframework.beans.factory.annotation.Value;
  5. import org.springframework.stereotype.Component;
  6. @Component
  7. public class HelloJob {
  8. @Value("${server.port}")
  9. private String port;
  10. @XxlJob("demoJobHandler")
  11. public ReturnT helloJob() {
  12. System.out.println("简单任务执行了。。。" + port);
  13. return ReturnT.SUCCESS;
  14. }
  15. }

启动项目,出现下面的提示说明启动成功
在这里插入图片描述

4. 在页面上创建执行器和任务,与项目中绑定

  1. 创建执行器【取值与springboot项目中配置文件一一对应】在这里插入图片描述
  2. 创建任务在这里插入图片描述在这里插入图片描述
  3. 启动,验证是否执行成功在这里插入图片描述 启动后查看调度日志,或者观察程序控制台数据在这里插入图片描述在这里插入图片描述

总结

如果启动失败,检查配置文件的值是否一致,如accessToken的值

参考

  1. https://developer.aliyun.com/article/1436105
  2. https://blog.csdn.net/m0_52985087/article/details/135646151
标签: spring boot 后端 java

本文转载自: https://blog.csdn.net/weixin_44220322/article/details/140689280
版权归原作者 世界需要行动派 所有, 如有侵权,请联系我们删除。

“springboot整合 xxl-job”的评论:

还没有评论