效果图:
1.xxl-job服务端项目代码图:
2.xxl-job服务端项目数据库图:
3.项目启动后界面呈现效果图:
这样就可以通过任务调度界面来控制和执行相应任务了;
Spring Boot 集成 XXL-JOB:
配置文件pom.xml:
<!-- 分布式任务调度平台XXL-JOB-->
<dependency>
<groupId>com.xuxueli</groupId>
<artifactId>xxl-job-core</artifactId>
<version>2.0.1</version>
</dependency>
配置文件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<String> execute(String s) throws Exception {
System.out.println("--------------------------->>testTask start");
return null;
}
}
这样springboot就与xxl-job集成完毕了;但是还需要在本地启动xxl-job的服务端;
xxl-job服务端的启动:
下载链接:
xxl-job源码下载
下载后如图:
用idea打开该项目,如图:
在本地mysql数据执行图中的sql文件(tables_xxl_job.sql),为xxl-job服务端创建所需要的数据库和相应的表;然后修改配置文件中的mysql数据库链接后方可启动成功;如图:
项目启动后,打开网址:http://localhost:8080/xxl-job-admin/,
默认账号和密码是admin/123456,登录成功后如图:
然后根据下图操作:其中AppName就是springboot项目配置中的xxl.job.executor.appname;
保存成功后,过一段时间就是显示如图的样子:
这是因为你的springboot项目会每过一段时间往xxl-job服务中注册自己的各种信息如图:
你也可以通过xxl-job服务中的数据库里查看到结果;(更有意思的是update_time字段是随之变化的)
在执行器管理中新增了我们springboot项目的执行器后,我们需要在任务管理的菜单中新增属于我们springboot项目的任务了,如图:
执行器选择我们刚才配置的执行器,这样触发任务的时候,才会触发到我们所写的springboot项目中相应的任务,就好比通过执行器的名称来寻找执行器对应的项目一样;其中JobHandler所填的内容就是springboot项目中TestTask.java文件中@JobHandler(value = “testtask”)注解value的值;
Cron值的意思为每一分钟执行一次;(在线Cron表达式生成器)
任务新增成功后,操作→执行一次后就会触发springboot项目中的任务了;