文章目录

  • 1. 概述
  • 2. 调度器配置
    • 2.1.依赖及配置
    • 2.2.任务实例
    • 2.3.调度中心管理配置
  • 3. 总结

1. 概述

在上一篇《XXL-JOB调度中心集群部署配置》中,我们已经得到了一个调度中心的集群,接下来只需要了解到如何配置调度器及创建定时任务就可以了。
本文的主要内容包括:

  • 配置并启动调度器
  • 创建并执行定时任务

2. 调度器配置

第一次配置调度器,可以参考源码路径下的SpringBoot示例项目进行配置,也可以参考的官方文档的配置。
调度器的配置非常简单,只需要3个步骤就可以完成配置。

2.1.依赖及配置

依赖包引入
执行器只需要引入XXL-JOB的core包,我们可以在当前已存在的SpringBoot服务中引入,也可以创建一个新的服务来进行引入,现在部署的调度中心版本为2.3.1,执行器也配置为相同的版本。

  • maven配置:
<dependency><groupId>com.xuxueli</groupId><artifactId>xxl-job-core</artifactId><version>2.3.1</version>
</dependency>
  • gradle配置:
implementation 'com.xuxueli:xxl-job-core:2.3.1'

properties配置
properties文件的配置,官网已经有了详细的描述:

### 调度中心部署根地址 [选填]:如调度中心集群部署存在多个地址则用逗号分隔。执行器将会使用该地址进行"执行器心跳注册"和"任务结果回调";为空则关闭自动注册;
xxl.job.admin.addresses=http://127.0.0.1:8080/xxl-job-admin
### 执行器通讯TOKEN [选填]:非空时启用;
xxl.job.accessToken=
### 执行器AppName [选填]:执行器心跳注册分组依据;为空则关闭自动注册
xxl.job.executor.appname=xxl-job-executor-sample
### 执行器注册 [选填]:优先使用该配置作为注册地址,为空时使用内嵌服务 ”IP:PORT“ 作为注册地址。从而更灵活的支持容器类型执行器动态IP和动态映射端口问题。
xxl.job.executor.address=
### 执行器IP [选填]:默认为空表示自动获取IP,多网卡时可手动设置指定IP,该IP不会绑定Host仅作为通讯实用;地址信息用于 "执行器注册" 和 "调度中心请求并触发任务";
xxl.job.executor.ip=
### 执行器端口号 [选填]:小于等于0则自动获取;默认端口为9999,单机部署多个执行器时,注意要配置不同执行器端口;
xxl.job.executor.port=9999
### 执行器运行日志文件存储磁盘路径 [选填] :需要对该路径拥有读写权限;为空则使用默认路径;
xxl.job.executor.logpath=/data/applogs/xxl-job/jobhandler
### 执行器日志文件保存天数 [选填] : 过期日志自动清理, 限制值大于等于3时生效; 否则, 如-1, 关闭自动清理功能;
xxl.job.executor.logretentiondays=30

我们可以把这个配置文件直接复制到项目中,需要注意修改下面几个位置:

# 调度中心地址修改为集群的地址
xxl.job.admin.addresses=http://ls.xxljob.cn/xxl-job-admin
# 因为调度中心配置的是default_token,此处我们保持一致
xxl.job.accessToken=default_token
# 指定执行器名称,每个服务都应该有不同的执行器名称,同一个服务的不同集群节点的执行器名称应该相同
xxl.job.executor.appname=my-simple-executor

properties的使用
properties文件配置完成后,我们需要将这些配置使用起来,在SpringBoot中可以通过@Value注解将配置文件中的值注入到字段中,然后我们就可以使用这些字段,初始化XXL-JOB的执行器对象,把这个执行器对象交给Spring托管就可以了。
代码配置可以查看xxl-job-executor-sample-springboot中的XxlJobConfig,在实际使用的时候可以直接把XxlJobConfig复制到自己的项目中去,也可以自行封装一个SpringBoot的starter包,在其他的项目中直接引入starter包进行使用,这里就不做赘述了。
最终,会使用XxlJobSpringExecutor生成一个Bean注册到Spring中,这个就是当前服务节点中的执行器对象,执行器对象会充当指挥官的角色,由它来调用不同的定时任务。

为了方便,代码直接放这儿了:

@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;@Beanpublic 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;}/*** 针对多网卡、容器内部署等情况,可借助 "spring-cloud-commons" 提供的 "InetUtils" 组件灵活定制注册IP;**      1、引入依赖:*          <dependency>*             <groupId>org.springframework.cloud</groupId>*             <artifactId>spring-cloud-commons</artifactId>*             <version>${version}</version>*         </dependency>**      2、配置文件,或者容器启动变量*          spring.cloud.inetutils.preferred-networks: 'xxx.xxx.xxx.'**      3、获取IP*          String ip_ = inetUtils.findFirstNonLoopbackHostInfo().getIpAddress();*/}

2.2.任务实例

我们需要注册一个Bean到Spring中,并使用@XxlJob告诉执行器哪个方法是需要进行调度的,代码如下:

import com.cdwl.paybase.common.config.XxlJobConfig;
import com.xxl.job.core.handler.annotation.XxlJob;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;@Component
public class MyJob {private final Logger logger = LoggerFactory.getLogger(XxlJobConfig.class);@XxlJob("mySimpleJob")public void mySimpleJob() {logger.info("执行自定义任务");}
}

注:当前的XXL-JOB是通过Http协议来进行通信的,需要依赖Tomcat,所以在需要引入web依赖。

implementation 'org.springframework.boot:spring-boot-starter-web'

配置好后,我们就可以启动SpringBoot服务了,启动后就会往调度中心的数据库中,注册一个执行器实例。
注册的数据存入到xxl_job_registry表中:

字段解释参考下面的执行器集群。

执行器集群
执行器也是支持集群的,只需要在properties文件中,将addressesappname配置为一样的就可以了。
此外,如果是在同一台机器上启动的话,还需要修改端口xxl.job.executor.port=9999为其他的数值。
启动第二个节点之后,注册数据如下:

  • registry_key: 执行器节点中配置的appname,即执行器名称。
  • registry_value: 执行器节点暴露的ip和端口号。

看到这个数据,不难猜到,registry_key是让调度中心用来获取执行器所有节点的请求地址的key,获取到请求地址后,就可以请求执行器的调度接口进行任务调度了。

2.3.调度中心管理配置

创建执行器

在执行器的服务实例启动完毕之后,还需要在调度中心的管理系统中配置对应的执行器,以及任务信息。
通过http://ls.xxljob.cn/xxl-job-admin打开管理平台,默认用户名、密码分别是admin123456,然后进行如下配置:

关于注册方式,如果选择手动录入,需要自行将执行器的ip地址填写到文本框中。
如果选择的是自动注册,就会自动获取上面提到的xxl_job_registry表中的ip地址列表,这种方式可以动态的感知到执行器的上下线,是一种更加合适的方式。

保存完成之后,就可以在列表中看到my-simple-executor这个执行器,点击查看就可以看到当前执行器的注册实例的ip地址啦。

需要注意的是:
这里的地址列表是保存在执行器表xxl_job_group中的,如果在页面创建完成之后,Online机器地址没有值,可以等待30秒左右再进行查询,因为注册完成的执行器实例,每30秒会更新一次注册信息,这里涉及到执行器实例的探活,本篇暂时不提,会在后面的原理分析中补充。

创建定时任务
操作到这里之后,距离成功就只有一步之遥了,我们需要在调度中心的管理平台上,给刚刚创建的自定义执行器配置一个定时任务,关联到执行器实例中使用@XxlJob注解的方法。


配置解释可以参考官方文档中的配置属性详细说明

简单的说,这里的配置表示每5秒钟执行一次my-simple-executor执行器实例中的mySimleJob任务。
保存后,将任务启动。

然后点击查询日志,可以看到,任务已经执行成功了。

至此,一个最简单的定时任务就已经完成啦。按照这个配置的流程,可以在生产环境中的任意一个SpringBoot服务上集成定时任务。

3. 总结

本篇讲解了在有了调度中心的基础上,如何配置执行器从而达到在服务中使用定时任务的过程。

  1. 在SpringBoot项目中引入xxl-core包。
  2. 编辑properties文件,并解析到字段中,然后使用这个配置初始化执行器。
  3. 编写定时任务方法,并使用@XxlJob注解,并配置任务名称。
  4. 在调度中心管理平台中,先创建执行器配置,有了执行器之后在对应的执行器分组下创建定时任务。

启动定时任务,之后就可以查看定时任务的执行效果了。

【分布式任务调度】(二)XXL-JOB执行器配置及定时任务的创建相关推荐

  1. quartz分布式集群部署并且可视化配置job定时任务

    2019独角兽企业重金招聘Python工程师标准>>> 项目使用quartz框架完成了定时任务集群部署调度,并且对quartz进一步封装完成在web界面可动态配置定时任务.定时任务如 ...

  2. 【分布式任务调度】(三)XXL-JOB调度中心对执行器的上下线感知实现原理

    文章目录 1. 前言 2. 调度关系 3. 执行器注册 3.1. 调度中心处理注册请求 3.2. 执行器发起注册请求 4. 执行器注销 4.1.主动注销 4.2. 被动注销 5.流程图 6. 总结 这 ...

  3. 【分布式任务调度】(一)XXL-JOB调度中心集群部署配置

    文章目录 1.概述 2.代码编译 2.1.代码下载 2.2.初始化与编译 3.集群部署 3.1.服务启动 3.2.反向代理 4.总结 1.概述 XXL-JOB是一款轻量级的分布式任务调度中间件,默认支 ...

  4. HarmonyOS分布式Demo,鸿蒙HarmonyOS 分布式任务调度的实现

    感谢关注HarmonyOS,为了便于大家学习特将鸿蒙2.0基础教学内容整理如下: 1.HarmonyOS应用开发―视频播放 https://developer.huawei.com/consumer/ ...

  5. python建站部署_SpringBoot入门建站全系列(三十二)接入xxl-job分布式任务调度平台...

    SpringBoot入门建站全系列(三十二)接入xxl-job分布式任务调度平台 一.概述 XXL-JOB是一个轻量级分布式任务调度平台,其核心设计目标是开发迅速.学习简单.轻量级.易扩展.现已开放源 ...

  6. 系列学习分布式任务调度 XXL-JOB 之第 1 篇 —— XXL-JOB 介绍(调度中心、执行器)

    一般来说,我们在 SpringBoot 项目里,如果需要定时处理一件事,我们最常用的做法是:在启动类增加注解 @EnableScheduling 启用任务调度,然后在 task 任务类的某个方法上增加 ...

  7. 分布式任务调度框架XXL-JOB --配置部署

    配置部署"调度中心" 调度中心项目:xxl-job-admin 作用:统一管理任务调度平台上调度任务,负责触发调度执行,并且提供任务管理平台. 步骤一:调度中心配置: 调度中心配置 ...

  8. java timer.schedule如何控制执行次数_Java 分布式任务调度平台:PowerJob 快速开始+配置详解...

    本文适合有 Java 基础知识的人群 作者:HelloGitHub-Salieri 引言 HelloGitHub 推出的<讲解开源项目>[1]系列. 项目地址: https://githu ...

  9. xxl子任务_阿里面试官:聊一下分布式任务调度有那些解决方案?

    作者:黄兆平 来源:http://blog.freshfood.cn/article/39 # 简介 随着系统规模的发展,定时任务数量日益增多,任务也变得越来越复杂,尤其是在分布式环境下,存在多个业务 ...

最新文章

  1. VS2012经常使用的快捷方式完成最全面
  2. 一个jsp内嵌一个jsp
  3. 一个故事讲清楚BIO NIO 异步
  4. CentOS 6.3下配置LVM(逻辑卷管理
  5. SAP UI技术演进过程
  6. 麦块不显示服务器,为什么开不了服务器啊!
  7. rhce考试试题以及答案_搞懂这套五年级数学上册期末考试试题(含答案),考试不担心...
  8. java freemarker_Java: FreeMarker的配置和使用
  9. oracle 索引 序列,【Oracle】表、视图、序列、索引
  10. EAST: An Efficient and Accurate Scene Text Detector
  11. python向下_如何在python中向下转换
  12. 机器人仿真技术学习笔记(一)
  13. PHP方法的重载主要格式,PHP函数重载方法及技巧
  14. java发送电子邮件以qq邮箱为例
  15. [转]Java中的随机数生成器:Random,ThreadLocalRandom,SecureRandom
  16. java自动行走_java数据结构实现机器人行走
  17. Http get与pos
  18. canvas+websocket+vue做一个你画我猜小游戏
  19. python解决鸡兔同笼_python解决鸡兔同笼问题
  20. mysql/hive求实际活动时间

热门文章

  1. StackExchange.Redis官方文档(四)【键、值以及通道】
  2. 闲得无聊,随手来一发,就当随笔罢
  3. 支持m2的主板换m2硬盘无法识别的问题,主板:七彩虹H410-T
  4. Expression 核心操作符、表达式、操作方法
  5. git如何查看本地分支及对应的远程分支
  6. pycharm不用下载汉化包修改语言为中文
  7. Log4j2的additivity属性(是否去除冗余日志)
  8. 自己做了一个USB电风扇
  9. ADFS 部署数据库AlwaysOn后应用端的连接字符串更改
  10. 操作系统——信号量例题