Spring Boot 集成 XXL-JOB分布式任务调度平台初识

效果图:

1.xxl-job服务端项目代码图:

2.xxl-job服务端项目数据库图:
Spring Boot 集成 XXL-JOB分布式任务调度平台初识_第1张图片
3.项目启动后界面呈现效果图:
Spring Boot 集成 XXL-JOB分布式任务调度平台初识_第2张图片
这样就可以通过任务调度界面来控制和执行相应任务了;

Spring Boot 集成 XXL-JOB:

配置文件pom.xml:

        
        
            com.xuxueli
            xxl-job-core
            2.0.1
        

配置文件application.properties:

#xxl_Job
### 调度中心部署跟地址 [选填]:如调度中心集群部署存在多个地址则用逗号分隔。执行器将会使用该地址进行"执行器心跳注册"和"任务结果回调";为空则关闭自动注册;
xxl.job.admin.addresses=http://127.0.0.1:8080/xxl-job-admin

### 执行器AppName [选填]:执行器心跳注册分组依据;为空则关闭自动注册
xxl.job.executor.appname=xxl-job-executor-shop-goods

### 执行器IP [选填]:默认为空表示自动获取IP,多网卡时可手动设置指定IP,该IP不会绑定Host仅作为通讯实用;地址信息用于 "执行器注册" 和 "调度中心请求并触发任务";
xxl.job.executor.ip=

### 执行器端口号 [选填]:小于等于0则自动获取;默认端口为9999,单机部署多个执行器时,注意要配置不同执行器端口;
xxl.job.executor.port=9998

### 执行器通讯TOKEN [选填]:非空时启用;
xxl.job.accessToken=

### 执行器运行日志文件存储磁盘路径 [选填] :需要对该路径拥有读写权限;为空则使用默认路径;
xxl.job.executor.logpath=/data/applogs/xxl-job/jobhandler

### 执行器日志保存天数 [选填] :值大于3时生效,启用执行器Log文件定期清理功能,否则不生效;
xxl.job.executor.logretentiondays=-1


#请求处理的超时时间
ribbon.ReadTimeout: 10000
#请求连接的超时时间
ribbon.ConnectTimeout: 3000

XxlJobConfig.java文件代码:

package com.example.shopgoods.controller.xxl_Job;

import com.xxl.job.core.executor.impl.XxlJobSpringExecutor;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;


@Configuration
public class XxlJobConfig {

    private Logger logger = LoggerFactory.getLogger(XxlJobConfig.class);

    @Value("${xxl.job.admin.addresses}")
    private String adminAddresses;

    @Value("${xxl.job.executor.appname}")
    private String appName;

    @Value("${xxl.job.executor.ip}")
    private String ip;

    @Value("${xxl.job.executor.port}")
    private int port;

    @Value("${xxl.job.accessToken}")
    private String accessToken;

    @Value("${xxl.job.executor.logpath}")
    private String logPath;

    @Value("${xxl.job.executor.logretentiondays}")
    private int logRetentionDays;


    @Bean(initMethod = "start", destroyMethod = "destroy")
    public XxlJobSpringExecutor xxlJobExecutor() {
        logger.info(">>>>>>>>>>> xxl-job config init.");
        XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();
        xxlJobSpringExecutor.setAdminAddresses(adminAddresses);
        xxlJobSpringExecutor.setAppName(appName);
        xxlJobSpringExecutor.setIp(ip);
        xxlJobSpringExecutor.setPort(port);
        xxlJobSpringExecutor.setAccessToken(accessToken);
        xxlJobSpringExecutor.setLogPath(logPath);
        xxlJobSpringExecutor.setLogRetentionDays(logRetentionDays);

        return xxlJobSpringExecutor;
    }

}

IJobHandler.java测试文件代码:

package com.example.shopgoods.controller.xxl_Job;

import com.xxl.job.core.biz.model.ReturnT;
import com.xxl.job.core.handler.IJobHandler;
import com.xxl.job.core.handler.annotation.JobHandler;
import org.springframework.stereotype.Component;

/**
 * @Author: zp
 * @Date: 2019/7/31 11:03
 * @Description:
 */
@JobHandler(value = "testtask")
@Component
public class TestTask extends IJobHandler {

    @Override
    public ReturnT execute(String s) throws Exception {
        System.out.println("--------------------------->>testTask  start");
        return null;
    }

}

这样springboot就与xxl-job集成完毕了;但是还需要在本地启动xxl-job的服务端;

xxl-job服务端的启动:

下载链接:
xxl-job源码下载
下载后如图:
Spring Boot 集成 XXL-JOB分布式任务调度平台初识_第3张图片
用idea打开该项目,如图:

在本地mysql数据执行图中的sql文件(tables_xxl_job.sql),为xxl-job服务端创建所需要的数据库和相应的表;然后修改配置文件中的mysql数据库链接后方可启动成功;如图:

项目启动后,打开网址:http://localhost:8080/xxl-job-admin/,
默认账号和密码是admin/123456,登录成功后如图:
Spring Boot 集成 XXL-JOB分布式任务调度平台初识_第4张图片
然后根据下图操作:其中AppName就是springboot项目配置中的xxl.job.executor.appname;
Spring Boot 集成 XXL-JOB分布式任务调度平台初识_第5张图片
保存成功后,过一段时间就是显示如图的样子:
Spring Boot 集成 XXL-JOB分布式任务调度平台初识_第6张图片
这是因为你的springboot项目会每过一段时间往xxl-job服务中注册自己的各种信息如图:

Spring Boot 集成 XXL-JOB分布式任务调度平台初识_第7张图片
你也可以通过xxl-job服务中的数据库里查看到结果;(更有意思的是update_time字段是随之变化的)
Spring Boot 集成 XXL-JOB分布式任务调度平台初识_第8张图片
在执行器管理中新增了我们springboot项目的执行器后,我们需要在任务管理的菜单中新增属于我们springboot项目的任务了,如图:
Spring Boot 集成 XXL-JOB分布式任务调度平台初识_第9张图片
执行器选择我们刚才配置的执行器,这样触发任务的时候,才会触发到我们所写的springboot项目中相应的任务,就好比通过执行器的名称来寻找执行器对应的项目一样;其中JobHandler所填的内容就是springboot项目中TestTask.java文件中@JobHandler(value = “testtask”)注解value的值;
Cron值的意思为每一分钟执行一次;(在线Cron表达式生成器)
任务新增成功后,操作→执行一次后就会触发springboot项目中的任务了;
Spring Boot 集成 XXL-JOB分布式任务调度平台初识_第10张图片

参考文献:

分布式任务调度平台XXL-JOB

你可能感兴趣的:(spring,boot2,XXL-JOB,springboot,XXL-JOB)