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

一,概述

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

二,逻辑图解

 三,部署步骤

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 依赖:
<!--xxl-job-->
<dependency>

    <groupId>com.xuxueli</groupId>

    <artifactId>xxl-job-core</artifactId>

</dependency>

然后配置执行器
@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 (该地址执行器将会使用到,作为回调地址)

5、执行任务 

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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值