一,概述
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的管理页面,找到任务管理,添加一个任务给学习服务执行器: