【SpringBoot高级篇】SpringBoot集成XXL-JOB分布式任务调度平台
- 简介
- 下载源码
- 部署任务调度平台
- 执行SQL脚本
- 部署任务平台
- 简单使用
- 初始化测试项目
- pom依赖
- SampleXxlJob
- 修改配置
- 调度平台配置执行器
- 任务管理添加任务
简介
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 void demoJobHandler() throws Exception {
XxlJobHelper.log("开始测试xxl-job demo1");
for (int i = 0; i < 5; i++) {
XxlJobHelper.log("开始生成:" + i);
TimeUnit.SECONDS.sleep(2);
}
// default success
}
@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");
}
}
修改配置
修改项目配置,启动demo项目
调度平台配置执行器
AppName为 demo项目中的指定的xxl.job.executor.appname=xxl-job-executor-lyw
OnLine机器地址: 配置了执行器,启动对应项目,会自动显示上线
任务管理添加任务
添加定时任务
启动任务
查看日志