当前位置: 首页 > news >正文

springboot整合 xxl-job

文章目录
  • 一、xxl-job是什么
  • 二、使用步骤
    • 1. 下载并运行管理端代码
    • 2. 访问管理页面,确认是否启动成功
    • 3. 配置执行器【在自己的springboot项目中配置】
    • 4. 在页面上创建执行器和任务,与项目中绑定
  • 总结
  • 参考

一、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, 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的值需要和执行器中配置的值(后面会写)一致

      xxl-job, access token

      xxl.job.accessToken=default_token

  3. 通过Application运行程序,也可以打包后通过jar命令启动

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

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

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

  1. 引入依赖

        <dependency>
            <groupId>com.xuxueli</groupId>
            <artifactId>xxl-job-core</artifactId>
            <version>2.4.0</version>
        </dependency>
    
  2. 添加配置文件

  • accessToken与前面配置一致,address对应管理端访问地址

  • executor(执行器)的配置与后面在页面上创建执行器时保持一致

    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 # 填充地址,假设执行器运行在本地
    ip: 127.0.0.1 # 填充本地IP,确保它与address配置一致
    port: 9999
    logpath: /data/applogs/xxl-job/jobhandler
    logretentiondays: -1

  1. 执行器组件配置

    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;
    }
    }

  2. 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("简单任务执行了。。。" + port);
        return  ReturnT.SUCCESS;
    }
    

    }

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

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

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

总结

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

参考

  1. https://developer.aliyun.com/article/1436105
  2. https://blog.csdn.net/m0_52985087/article/details/135646151

相关文章:

  • Transformer解析——(五)代码解析及拓展
  • Spark 性能优化(四):Cache
  • 【含文档+PPT+源码】基于Django的新闻推荐系统的设计与实现
  • 【Python爬虫(36)】深挖多进程爬虫性能优化:从通信到负载均衡
  • RPA-实例(UiPath )
  • 一文讲解Redis的持久化方式及各自的区别
  • 飞书API
  • 精准测量PMD:OCI-V光矢量分析系统赋能光纤通信性能优化
  • Angular 中获取 DOM 节点的几种方法
  • go 错误处理 error
  • ncrfp:一种基于深度学习的端到端非编码RNA家族预测新方法
  • docker面试题
  • 自动化办公|xlwings生成图表
  • [Android]APP自启动
  • 探寻 AI 发展新航道:下一个 “S 曲线” 的突破点在哪?
  • 探索关键领域的AI工具:机器学习、深度学习、计算机视觉与自然语言处理
  • 深入理解 Java Servlet:从基础到实战
  • vue3学习1
  • Spring Boot 应用(官网文档解读)
  • 新能源汽车核心元件揭秘:二极管、三极管结构与工作原理解析(2/2)
  • 为何选择上海?两家外企提到营商环境、人才资源……
  • 知名猎头公司创始人兼首席执行官庄华因突发疾病逝世,享年62岁
  • “老中青少”四代同堂,季春艳携锡剧《玲珑女》冲击梅花奖
  • 孙卫东会见巴基斯坦驻华大使:支持巴印两国实现全面持久停火
  • 中拉论坛部长级会议为何悬挂海地和圣卢西亚的国旗?外交部回应
  • 极限拉扯上任巴西,安切洛蒂开启夏窗主帅大挪移?