服务端
官网:https://www.jianshu.com/p/fa7186bea84b
源码:https://github.com/xuxueli/xxl-job/
下载后配置一些本地的数据库导入sql如图
启动就行
http://localhost:8080/xxl-job-admin 登陆
账号:admin;密码:123456
先建立执行器
在建立任务(选择自定义设置的执行器)
创建任务
测试
任务列表可点击执行一次测试,正常运行点击执行就行
客户端
maven导入jar
<dependency>
<groupId>com.xuxueli</groupId>
<artifactId>xxl-job-core</artifactId>
<version>2.1.2</version>
</dependency>
加入config类
@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;
}
测试类
@JobHandler(value = "demoJobHandler")
@Component
public class demo extends IJobHandler {
@Override
public ReturnT<String> execute(String s) throws Exception {
System.out.println("自定义测试");
return null;
}
}
yml配置文件
xxl:
job:
### 执行器通讯TOKEN [选填]:非空时启用;
accessToken: ''
admin:
### 调度中心部署跟地址 [选填]:如调度中心集群部署存在多个地址则用逗号分隔。执行器将会使用该地址进行"执行器心跳注册"和"任务结果回调";为空则关闭自动注册;
addresses: http://192.168.10.40:8080/xxl-job-admin
executor:
### 执行器AppName [选填]:执行器心跳注册分组依据;为空则关闭自动注册
appname: sms-platfrom
ip: 192.168.10.40 //本地id,在admin端执行器中也要配置
logpath: /data/applogs/xxl-job/jobhandler
logretentiondays: 30
port: 8888