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数量,对每个节点进行内部分页处理

经验分享 程序员 微信小程序 职场和发展