【SpringBoot高级篇】SpringBoot集成XXL-JOB分布式任务调度平台

简介

XXL-JOB是一个分布式任务调度平台,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线,开箱即用。

项目地址: https://gitee.com/xuxueli0323/xxl-job

下载源码

源码地址:https://gitee.com/xuxueli0323/xxl-job

在这里插入图片描述

git clone 到本地,使用idea打开

在这里插入图片描述

或者使用idea直接拉项目在这里插入图片描述

部署任务调度平台

执行SQL脚本

在这里插入图片描述

执行SQL脚本,生成相关的表

在这里插入图片描述

部署任务平台

简单测试 可以直接启动xxl-job-admin项目的mian使用

1、修改数据源用户名/密码

在这里插入图片描述

2、maven install/package 打包到本地库在这里插入图片描述

3、cmd窗口,java -jar xxl-job-admin-2.4.0-SNAPSHOT.jar启动项目

在这里插入图片描述

4、任务调度平台地址:http://localhost:8080/xxl-job-admin/ 用户名: admin 密码:123456

在这里插入图片描述

简单使用

初始化测试项目

新建springboot项目,拷贝下面的文件到自己项目中

在这里插入图片描述

pom依赖

<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <!-- xxl-job-core -->
    <dependency>
        <groupId>com.xuxueli</groupId>
        <artifactId>xxl-job-core</artifactId>
        <version>2.3.0</version>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-tomcat</artifactId>
    </dependency>
</dependencies>

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>

SampleXxlJob

/**
 * XxlJob开发示例(Bean模式)
 *
 * 开发步骤:
 *      1、任务开发:在Spring Bean实例中,开发Job方法;
 *      2、注解配置:为Job方法添加注解 "@XxlJob(value="自定义jobhandler名称", init = "JobHandler初始化方法", destroy = "JobHandler销毁方法")",注解value值对应的是调度中心新建任务的JobHandler属性的值。
 *      3、执行日志:需要通过 "XxlJobHelper.log" 打印执行日志;
 *      4、任务结果:默认任务结果为 "成功" 状态,不需要主动设置;如有诉求,比如设置任务结果为失败,可以通过 "XxlJobHelper.handleFail/handleSuccess" 自主设置任务结果;
 *
 */
@Component
public class SampleXxlJob {
    
    
    private static Logger logger = LoggerFactory.getLogger(SampleXxlJob.class);
    /**
     * 1、简单任务示例(Bean模式)
     */
   @XxlJob("lywJobHandler")
    public ReturnT<String> demoJobHandler() throws Exception {
    
    
        // 打印任务日志
        XxlJobHelper.log("开始测试xxl-job demo1");

        // 获取任务参数
        String jobParam = XxlJobHelper.getJobParam();
        ObjectMapper objectMapper = new ObjectMapper();
        Map map = objectMapper.readValue(jobParam, Map.class);

        XxlJobHelper.log("map: "+ map);
        logger.info("jobParam: {}", map);
        for (int i = 0; i < 5; i++) {
    
    
            XxlJobHelper.log("开始生成:" + i);
           // TimeUnit.SECONDS.sleep(2);
        }
        // default success
        return ReturnT.FAIL;
    }
    @XxlJob("dayJobHandler")
    public void dayJobHandler() throws Exception {
    
    
        XxlJobHelper.log("开始测试xxl-job demo2");

        for (int i = 0; i < 5; i++) {
    
    
            XxlJobHelper.log("开始生成:" + i);
            TimeUnit.SECONDS.sleep(2);
        }
        // default success
    }

    /**
     * 5、生命周期任务示例:任务初始化与销毁时,支持自定义相关逻辑;
     */
    @XxlJob(value = "demoJobHandler2", init = "init", destroy = "destroy")
    public void demoJobHandler2() throws Exception {
    
    
        XxlJobHelper.log("XXL-JOB, Hello World.");
    }
    public void init(){
    
    
        logger.info("init");
    }
    public void destroy(){
    
    
        logger.info("destroy");
    }
}
  • XxlJobHelper.log(“开始测试xxl-job demo1”); 打印日志
  • XxlJobHelper.getJobParam(); 获取参数

修改配置

修改项目配置,启动demo项目在这里插入图片描述

调度平台配置执行器

AppName为 demo项目中的指定的xxl.job.executor.appname=xxl-job-executor-lyw

在这里插入图片描述

OnLine机器地址: 配置了执行器,启动对应项目,会自动显示上线

在这里插入图片描述

任务管理添加任务

添加定时任务

在这里插入图片描述

启动任务

在这里插入图片描述

查看日志

在这里插入图片描述

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_45297578/article/details/128786200