xxlJob 分布式定时任务
1.下载地址
https://github.com/xuxueli/xxl-job
2.打开项目,并创建xxl-job数据库
3.修改xxl-job-admin配置并启动
默认账号 admin 默认密码 123456
4. 配置springboot项目,注册到xxljob中
4.1 引入maven依赖
<dependency> <groupId>com.xuxueli</groupId> <artifactId>xxl-job-core</artifactId> <version>2.3.0</version> </dependency>
4.2 修改 application.yml
xxl: job: admin: ##注册到启动的xxljob服务中 addresses: http://127.0.0.1:8888/xxl-job-admin accessToken: default_token executor: ##执行器名称 appname: xxl-job-executor-sample ##监听端口 同一服务下端口不能重复 port: 9999 logpath: /data/applogs/xxl-job/jobhandler logretentiondays: 30 address: ip: 127.0.0.1
4.3 增加config配置
@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; } }
4.4 增加任务处理器 新版本中取消了 @JobHandler 注解,采用了@XxlJob注解
@Component public class SampleXxlJob { private static Logger logger = LoggerFactory.getLogger(SampleXxlJob.class); @XxlJob("demoJobHandler") public void demoJobHandler() throws Exception { String param = XxlJobHelper.getJobParam();//参数信息 logger.info(param); XxlJobHelper.log("XXL-JOB, Hello World.");//日志打印会输出到任务里 } }
5. 将项目配置到 xxljob 中
5.1 配置执行器
5.2 配置任务 5.3 设置任务状态,也可以单独执行一次
5.4 查看日志信息 5.5 路由策略-分片广播 在任务管理中,路由策略都是在单个节点上执行,如果单个节点扛不住会产生事故,为了处理这种情况我们用到了分片广播,也就是所有的节点都会执行,每个服务可以执行对应的数据,缓解服务端压力
@XxlJob("demo") public void demo(){ String jobParam = XxlJobHelper.getJobParam(); System.out.println(jobParam); int shardIndex = XxlJobHelper.getShardIndex();//执行的第几个节点,从0开始 int shardTotal = XxlJobHelper.getShardTotal();//所有节点数量 System.out.println("shardIndex "+shardIndex); System.out.println("shardTotal "+shardTotal); }
##打印信息 100 shardIndex 0 shardTotal 2
引入业务之后,参数作为每页数量,将index作为页数、total数量,对每个节点进行内部分页处理