SpringBoot项目快速集成xxL-Job分布任务调度平台

项目场景:

定时任务

Spring项目开发大多数使用Spring-Scheduler,只需在Spring中的bean的对应方法加上@Scheduled注解,在启动类上面加上 @EnableScheduling 注解开启定时任务,此种方式不能保证定时任务执行多次:于是采用了xxl-job分布式任务调度中心


  1. 介绍

1.xxl-job是一个分布式定时任务调度框架,功能强大,底层使用自己实现的rpc框架进行注册和管理,数据库使用mysql,调度触发使用数据库锁来作为调度锁。
2.xxl-job主要分为调度中心admin以及任务,任务引入依赖jar包并配置启动类为spring所管理的bean后,将自动通过spring-bean提供的initMethod进行启动线程选择一个端口进行注册以及监听任务调度。
3.主要分为 调度中心和执行器两部分 , 调度中心在启动初始化的时候,会默认生成执行器的RPC代理对象(http协议调用), 执行器项目启动之后, 调度中心在触发定时器之后通过jobHandle 来调用执行器项目里面的代码

  1. 优点
  • 动态:支持动态修改任务状态、启动/停止任务,以及终止运行中任务,即时生效;
  • 执行器HA(分布式):任务分布式执行,任务”执行器”支持集群部署,可保证任务执行HA;
  • 注册中心: 执行器会周期性自动注册任务,调度中心将会自动发现注册的任务并触发执行。也支持手动录入
  1. 缺点
  • 缺点:调度中心通过获取 DB锁来保证集群中执行任务的唯一性,如果短任务很多,随着调度中心集群数量增加,那么数据库的锁竞争会比较厉害,性能不好。

项目实战

主要分为二部分:调度中心和项目集成

1.调度中心

通过访问以下地址clone调度中心源码

GitHub地址:https://github.com/xuxueli/xxl-job

Gitee地址:https://gitee.com/xuxueli0323/xxl-job

操作:执行项目中doc目录下db数据sql脚本,修改application.properties中数据库连接配置,账户密码,以及访问部署的端口号。启动类执行成功后,访问http://ip:端口/admin,默认账户登录admin,密码123456


2.集成SringBoot项目
第一步:pom.xml依赖注入

		<!--分布式任务调度平台-->
        <dependency>
            <groupId>com.xuxueli</groupId>
            <artifactId>xxl-job-core</artifactId>
            <version>2.3.1</version>
        </dependency>

第二步:环境变量信息配置

xxl:
  job:
    admin:
      addresses: http://ip:端口/xxl-job-admin
    accessToken: default_token
    executor:
      appname: zpa-job
      address: 
      ip: 
      port: 9999
      # 日志地址
      logpath: /data/applogs/xxl-job/jobhandler
      # 日志保存时间
      logretentiondays: 30

第三步:配置Configuration类的Bean

@Configuration
public class XxlJobConfiguration {

    @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() {
        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;
    }

第四步:通过@XxlJob注解指定“TestJobByYuan”一个任务,

@Component
public class TestJob {

    private static final Logger logger = LoggerFactory.getLogger(TestJob.class);

    @XxlJob("TestJobByYuan")
    public void testJob() {
        logger.info("TestJobByYuan任务执行了。。。");
    }

}

第五步:登录调度中心管理,找到执行器管理监测OnLine机器,然后通过任务管理新增一个刚才通过@XxlJob注解指定“TestJobByYuan”一个任务,配置页面信息,启动执行验证,最终控制台输出“TestJobByYuan任务执行了。。。”

总体分析:

XXL-JOB是一个任务调度框架,通过引入XXL-JOB相关的依赖,按照相关格式撰写代码后,可在其可视化界面进行任务的启动,执行,中止以及包含了日志记录与查询和任务状态监控


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值