XXL-JOB详解以及如何在项目中使用,和拟解决的问题

一,概述

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

二,逻辑图解

XXL-JOB详解以及如何在项目中使用,和拟解决的问题_第1张图片

 三,部署步骤

1,部署调度中心

我们提供的开发环境虚拟机中已经部署完成,如果要自行部署,可以按照下列步骤:

运行资料中提供的,初始化 SQL 文件,创建 XXL-JOB 所需表
参考以下 Docker 命令创建容器
docker run \
-e PARAMS="--spring.datasource.url=jdbc:mysql://192.168.150.101:3306/xxl_job?Unicode=true&characterEncoding=UTF-8 \
--spring.datasource.username=root \
--spring.datasource.password=123" \
--restart=always \
-p 8880:8080 \
-v xxl-job-admin-applogs:/data/applogs \
--name xxl-job-admin \
-d \
xuxueli/xxl-job-admin:2.3.0
2,微服务集成执行器(XXL-JOB依赖)
首先是引入 XXL-JOB 依赖:



    com.xuxueli

    xxl-job-core



然后配置执行器
@Bean
public XxlJobSpringExecutor xxlJobExecutor() {
    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;
}
3、编写任务(Bean模式)

定义一个SpringBean,在其中利用@XxlJob注解来定义要执行的任务:

@Slf4j
@Component
public class CreateTableHandler {
    @XxlJob("createTableJob")
    public void createPointsBoardTableBySeason(){
        log.debug("开始执行创建历史榜单表的任务");
    }
}
4、注册执行器

重启服务后,登录XXL-JOB管理页面,然后注册一个执行器:

调度中心访问地址:http://localhost:8080/xxl-job-admin (该地址执行器将会使用到,作为回调地址)

XXL-JOB详解以及如何在项目中使用,和拟解决的问题_第2张图片

XXL-JOB详解以及如何在项目中使用,和拟解决的问题_第3张图片

5、执行任务 

进入XXL-JOB的管理页面,找到任务管理,添加一个任务给学习服务执行器:

XXL-JOB详解以及如何在项目中使用,和拟解决的问题_第4张图片

 XXL-JOB详解以及如何在项目中使用,和拟解决的问题_第5张图片

你可能感兴趣的:(java)