XXL-Job执行器部署
执行器项目demo配置:
将依赖导入demo-biz的pom
1、导入xxl-job定时任务依赖,自行百度查找
2、加入执行器配置:配置中的addresses要与调度中心的地址保持一致,appname要与调度中心web页面中创建执行器时的appname保持一致
#执行器配置
xxl:
job:
admin: #接口地址,执行器将会使用该地址进行"执行器心跳注册"和"任务结果回调"
addresses: http://${MYSQL-HOST:newx-mysql}:9080/xxl-job-admin
accessToken:
executor: #分别配置执行器的名称、ip地址、端口号,如果配置多个执行器时,防止端口冲突
ip:
port: 9990
appname: xxl-job-executor-test
logpath: /data/applogs/xxl-job/jobhandler #执行器运行日志文件存储的磁盘位置,需要对该路径拥有读写权限
logretentiondays: 30 #执行器Log文件定期清理功能,调度中心日志表数据保存天数,-1表示永不删除
配置执行器组件:
@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
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;
}
}
3、在调度中心创建执行器
4、开发一个demo任务:
@Component
public class TestTask {
@XxlJob(“testHandler”)
public ReturnT demoJobHandler(String param) throws Exception {
XxlJobLogger.log(“XXL-JOB, Hello World.”);
System.out.println(“zxxxx”);
XxlJobLogger.log(“XXL-JOB, Hello World end.”);
return ReturnT.SUCCESS;
}
}
5、在调度中心选定刚才创建的执行器,创建一个任务:@XxlJob注解里的值与调度中心任务中的值保持一致