Springboot整合XXL-job
1、开发步骤:
pom.xml
<!--xxl-job--> <dependency> <groupId>com.xuxueli</groupId> <artifactId>xxl-job-core</artifactId> <version>2.3.1</version> </dependency>
application.properties
# web port
server.port=8082
# no web
#spring.main.web-environment=false
### xxl-job-admin服务地址
xxl.job.admin.addresses=http://127.0.0.1:8081/xxl-job-admin
### xxl-job-admin服务token
xxl.job.accessToken=default_token
### xxl-job-admin服务页面,执行器管理中新增,appname
xxl.job.executor.appname=xxl-job-executor-sample
### xxl-job executor registry-address: default use address to registry , otherwise use ip:port if address is null
xxl.job.executor.address=
### xxl-job executor server-info
xxl.job.executor.ip=
xxl.job.executor.port=9999
### xxl-job executor log-path
xxl.job.executor.logpath=/data/applogs/xxl-job/jobhandler
### xxl-job executor log-retention-days
xxl.job.executor.logretentiondays=30
XXL配置类
package com.xxl.job.executor.core.config; 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; /** * xxl-job config * * @author xuxueli 2017-04-28 */ @Configuration public class XxlJobConfig { private Logger logger = LoggerFactory.getLogger(XxlJobConfig.class); @Value("${xxl.job.admin.addresses}") private String adminAddresses; @Value("${xxl.job.accessToken}") private String accessToken; @Value("${xxl.job.executor.appname}") private String appname; @Value("${xxl.job.executor.address}") private String address; @Value("${xxl.job.executor.ip}") private String ip; @Value("${xxl.job.executor.port}") private int port; @Value("${xxl.job.executor.logpath}") private String logPath; @Value("${xxl.job.executor.logretentiondays}") private int logRetentionDays; @Bean public XxlJobSpringExecutor xxlJobExecutor() { logger.info(">>>>>>>>>>> xxl-job config init."); XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor(); xxlJobSpringExecutor.setAdminAddresses(adminAddresses); xxlJobSpringExecutor.setAppname(appname); xxlJobSpringExecutor.setAddress(address); xxlJobSpringExecutor.setIp(ip); xxlJobSpringExecutor.setPort(port); xxlJobSpringExecutor.setAccessToken(accessToken); xxlJobSpringExecutor.setLogPath(logPath); xxlJobSpringExecutor.setLogRetentionDays(logRetentionDays); return xxlJobSpringExecutor; } /** * 针对多网卡、容器内部署等情况,可借助 "spring-cloud-commons" 提供的 "InetUtils" 组件灵活定制注册IP; * * 1、引入依赖: * <dependency> * <groupId>org.springframework.cloud</groupId> * <artifactId>spring-cloud-commons</artifactId> * <version>${version}</version> * </dependency> * * 2、配置文件,或者容器启动变量 * spring.cloud.inetutils.preferred-networks: 'xxx.xxx.xxx.' * * 3、获取IP * String ip_ = inetUtils.findFirstNonLoopbackHostInfo().getIpAddress(); */ }
开发定时任务
import com.gao.配置类.XxlConfig; import com.xxl.job.core.biz.model.ReturnT; import com.xxl.job.core.context.XxlJobHelper; import com.xxl.job.core.handler.annotation.XxlJob; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component; import static com.xxl.job.core.biz.model.ReturnT.FAIL; import static com.xxl.job.core.biz.model.ReturnT.SUCCESS; @Component public class MyTestHandler { private final Logger log = LoggerFactory.getLogger(XxlConfig.class); //@XxlJob(value="自定义jobhandler名称", init = "JobHandler初始化方法", destroy = "JobHandler销毁方法") @XxlJob(value="自定义jobhandler名称") public void myTestHandler() { XxlJobHelper.log("XXL-JOB, Hello World."); System.out.println("测试demo myTestHandler...."); } @XxlJob("myTestHandler") public ReturnT<String> execute() throws Exception { log.info(" >>用户等级更新任务开始执行...."); System.out.println("myTestHandler"); try { //自定义调用接口 System.out.println("invoke execute...."); // userService.updateLevel(); return SUCCESS; } catch (Exception e) { log.info(String.valueOf(e)); return FAIL; } } }
2、XXL-job-admin页面相关操作
任务管理-->选择执行器-->新增
新增
查看 任务管理 ,默认状态是停止的
启动定时任务
查看日志
代码效果