xxl-job安装与使用

介绍

  1. 问题
    分布式系统,每个项目上都有多个定时任务,到点的时候每个主机都运行一遍就出现了问题
  2. xxl-job
    xxl-job是分布式任务调度平台,轻量级,学习简单,并且是开源,很多大公司都是使用 官网

调度中心

  1. 源码下载gitee
  2. 将整个项目克隆下来,在xxl-job\doc\db下有一个sql语句,在本地数据库运行
  3. 修改xxl-job-admin数据库连接地址,账号,密码
  4. 直接启动,访问http://127.0.0.1:8080/xxl-job-admin/账号admin 密码123456

执行器

  1. 创建一个springboot项目,引入xxl-core
    <dependency>
    	<groupId>com.xuxueli</groupId>
        <artifactId>xxl-job-core</artifactId>
        <version>2.3.0</version>
    </dependency>
    
  2. 配置执行器
    1. 配置文件

      # 调度中心地址
      xxl.job.admin.addresses=http://127.0.0.1:8080/xxl-job-admin
      # app名称
      xxl.job.executor.appname=xxl-job-executor-sample1
      
    2. 配置xxljob执行器

      package cn.jaminye.xxljobdemo.config;
      
      import com.xxl.job.core.executor.impl.XxlJobSpringExecutor;
      import org.springframework.beans.factory.annotation.Value;
      import org.springframework.context.annotation.Bean;
      import org.springframework.context.annotation.Configuration;
      
      /**
       * @author Jamin
       * @date 2021/6/23 17:22
       */
      @Configuration
      public class XxlJobConfig {
      
          @Value("${xxl.job.admin.addresses}")
          private String adminAdresses;
      
          @Value("${xxl.job.executor.appname}")
          private String appname;
      
          @Bean
          public XxlJobSpringExecutor xxlJobSpringExecutor() {
              XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();
              xxlJobSpringExecutor.setAdminAddresses(adminAdresses);
              xxlJobSpringExecutor.setAppname(appname);
              return xxlJobSpringExecutor;
          }
      
      }
      
    3. 修改启动类

      package cn.jaminye.xxljobdemo;
      import org.springframework.boot.SpringApplication;
      import org.springframework.boot.autoconfigure.SpringBootApplication;
      
      import java.util.concurrent.CountDownLatch;
      
      @SpringBootApplication
      public class XxlJobDemoApplication {
          public static void main(String[] args) throws InterruptedException {
              SpringApplication.run(XxlJobDemoApplication.class, args);
              //让程序不结束
              new CountDownLatch(1).await();
          }
       }     
      
    4. 执行器配置

      1. 打开调度中心
      2. 选择执行器管理
      3. 添加,AppName输入执行器配配置的AppName
      4. 启动执行,可以从控制台看到注册成功,以及调度中心online机器地址(没有配置主机ip会自动获取,ip默认为9999)
    5. 创建任务

      1. 这里创建一个简单的执行器
        package cn.jaminye.xxljobdemo.service;
         
        import com.xxl.job.core.handler.annotation.XxlJob;
        import org.springframework.stereotype.Component;
         
        /**
         * @author Jamin
         * @date 2021/6/23 17:26
         */
        @Component
        public class SampleXxlJob {
         
            @XxlJob("demoJobHandler")
            public void demoJobHandler() throws InterruptedException {
                Logger logger = LoggerFactory.getLogger(SampleXxlJob.class);
        	    //控制台日志
        	    logger.info("123");
        	    // 执行日志
                XxlJobHelper.log("123");
        	    Thread.sleep(2000);
        	}
        }
        
      2. 任务配置
        主要配置cron表达式(这里测试使用1秒钟1次)与JobHandler(XxlJob注解中的值)

        点击调度日志,可查看执行结果,调度时间与执行时间,可以看到它是实时调度,但执行等上一个执行完成才执行

        查看控制台可以看到代码中控制台打印的日志,在执行日志中可以看到xxl打印的日志
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jamin_Ye

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值