13.XXL-JOB应用

XXL-JOB应用

1.介绍

XXL-JOB是大众点评员工徐雪里于2015年发布的分布式任务调度平台

2.XXL-JOB与Quartz的关系

老版本依赖Quartz的定时任务触发,在V2.1.0版本开始移除了Quartz

3.官方地址

  • 官方文档:https://www.xuxueli.com/xxl-job/
  • gitee:https://gitee.com/xuxueli0323/xxl-job
  • github:https://github.com/xuxueli/xxl-job/
  • dockerhub:https://hub.docker.com/r/xuxueli/xxl-job-admin/

4.设计思想

  • 将调度行为抽象形成“调度中心”公共平台,而平台自身并不承担业务逻辑,“调度中心”负责发起调度请求
  • 将任务抽象成分散的JobHandler,交友“执行器”统一管理
  • “执行器”负责接收调度请求并执行对应的JobHandler中业务逻辑
  • 因此,“调度”和“任务”两部分可以互相解耦,提高系统整体稳定性和扩展性

5.架构

调度中心

  • 负责管理调度的信息,按照调度的配置来发出调度请求
  • 支持可视化,简单的动态管理调度信息,包括新建,删除,更新等,这些操作都会实时生效,同时也支持监控调度结果以及执行日志

执行器

负责接收请求并且执行任务的逻辑。任务模块专注于任务的执行操作等等,使得开发和维护更加简单与高效

图示

在这里插入图片描述

6.特点

  • 调度中心HA(中心式):调度采用了中心式进行设计,“调度中心”支持集群部署,可保证调度中心HA
  • 执行器HA(分布式):任务分布式的执行,任务执行器支持集群部署,可保证任务执行HA
  • 触发策略:用cron触发,固定间隔触发,固定延时触发,API事件触发,人工触发,父子任务触发
  • 路由策略:执行器在集群部署的时候提供了丰富的路由策略,如:第一个,最后一个,轮询,随机,一致性Hash,最不经常使用LFU,最久未使用LRU,故障转移等等
  • Rolling实时日志的监控:支持rolling方式查看输入的完整执行日志
  • 脚本任务:支持GLUE模式开发和运行脚本任务,包括Shell,python,node.js,php等等类型脚本

7.源码

版本

V2.3.0

下载地址

https://github.com/xuxueli/xxl-job/releases/tag/2.3.0

源码目录介绍

  • doc:xxl-job的文档资料,包括了数据库的脚本
  • xxl-job-core:公共jar包依赖
  • xxl-job-admin:调度中心,项目源码,是SpringBoot项目,可以直接启动
  • xxl-job-executor-samples:执行器,是Sample实例项目,里面的SpringBoot工程可以直接启动,也可以在该项目的基础上进行开发,也可以将现有的项目改造为执行器项目

表介绍

  • xxl_job_group:执行器信息表,用于维护任务执行器的信息
  • xxl_job_info:调度扩展信息表,主要是用于xxl-job的调度任务的扩展信息,比如说像任务分组,任务名,机器的地址等等
  • xxl_job_lock:任务调度锁表
  • xxl_job_log:日志表,主要是用在保存xxl-job任务调度历史信息,像调度结果,执行结果,调度入参等
  • xxl_job-log_report:日志报表,会存储xxl-job任务调度的日志报表,会在调度中心里的报表功能里使用到
  • xxl_job_logglue:任务的GLUE日志,用于保存GLUE日志的更新历史变化,支持GLUE版本的回溯功能
  • xxl_job_user:系统的用户表

8.部署

方式总览

  • 手动部署
  • Docker部署

部署架构图

在这里插入图片描述

手动部署

步骤
  • 拉取源码
  • 从源码中获取sql文件并执行
  • 配置源码中的数据库路径信息
  • 启动admin应用
拉取源码

省略…上面给了源码地址下载即可

从源码中获取sql文件并执行

在这里插入图片描述
在这里插入图片描述

配置源码中的数据库路径信息

在这里插入图片描述

启动admin应用

省略…就是个SpringBoot应用直接执行就行

Docker部署

# 拉取镜像,建议加版本
docker pull xuxueli/xxl-job-admin# 如需自定义 mysql 等配置,可通过 "-e PARAMS" 指定,参数格式 PARAMS="--key=value  --key2=value2" ;
# 配置项参考文件:/xxl-job/xxl-job-admin/src/main/resources/application.properties
# 如需自定义 JVM内存参数 等配置,可通过 "-e JAVA_OPTS" 指定,参数格式 JAVA_OPTS="-Xmx512m" ;
docker run -e PARAMS="--spring.datasource.url=jdbc:mysql://127.0.0.1:3306/xxl_job?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai" -p 8080:8080 -v /tmp:/data/applogs --name xxl-job-admin  -d xuxueli/xxl-job-admin:{指定版本}

测试是否部署成功

访问调度中心控制台,能进去就算成功

  • 地址:ip:8080/xxl-job-admin
  • 默认账号密码:admin/123456

在这里插入图片描述
在这里插入图片描述

服务端配置文件详解

### 调度中心JDBC链接:链接地址请保持和 2.1章节 所创建的调度数据库的地址一致
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/xxl_job?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai
spring.datasource.username=root
spring.datasource.password=root_pwd
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
### 报警邮箱
spring.mail.host=smtp.qq.com
spring.mail.port=25
spring.mail.username=xxx@qq.com
spring.mail.password=xxx
spring.mail.properties.mail.smtp.auth=true
spring.mail.properties.mail.smtp.starttls.enable=true
spring.mail.properties.mail.smtp.starttls.required=true
spring.mail.properties.mail.smtp.socketFactory.class=javax.net.ssl.SSLSocketFactory
### 调度中心通讯TOKEN [选填]:非空时启用;
xxl.job.accessToken=
### 调度中心国际化配置 [必填]: 默认为 "zh_CN"/中文简体, 可选范围为 "zh_CN"/中文简体, "zh_TC"/中文繁体 and "en"/英文;
xxl.job.i18n=zh_CN
## 调度线程池最大线程配置【必填】
xxl.job.triggerpool.fast.max=200
xxl.job.triggerpool.slow.max=100
### 调度中心日志表数据保存天数 [必填]:过期日志自动清理;限制大于等于7时生效,否则, 如-1,关闭自动清理功能;
xxl.job.logretentiondays=30

9.SpringBoot整合XXL-JOB

依赖

<dependency><groupId>com.xuxueli</groupId><artifactId>xxl-job-core</artifactId><version>2.3.0</version>
</dependency>

application.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

配置类

@Bean
public XxlJobSpringExecutor xxlJobExecutor() {logger.info(">>>>>>>>>>> xxl-job config init.");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;
}

基础知识

在这里插入图片描述

创建Job方法

在这里插入图片描述

页面创建任务

在这里插入图片描述

注意

SpringBoot项目启动后,执行器上显示在线机器一般要等30秒左右才回显的地址

页面执行任务

在这里插入图片描述

10.执行器多节点执行

介绍

执行器有多个然后同一个任务,调度中心去调度多个执行器

本机执行器多节点部署

  • 程序端口修改
  • 执行器端口修改
# 第一个要改的配置
server.port=8080
# 第二个要改的配置
xxl.job.executor.port=9999

执行

在这里插入图片描述

11.调度任务参数传递

介绍

在页面运行一个任务的时候可以编辑这个任务执行的时候传递的参数,然后再执行器的应用中使用XxlJobHelper.getJobParam()方法获得参数

UI界面设置

在这里插入图片描述

代码

在这里插入图片描述

12.调度任务日志打印与查看

介绍

调度任务的时候可以在代码里面打印一些日志,然后控制台上可以方便查看

代码

在这里插入图片描述

UI界面

在这里插入图片描述
在这里插入图片描述

13.自主设置调度任务执行结果

介绍

存在调度是否成功与执行是否成功,那么如何控制任务执行是否成功呢
在这里插入图片描述

默认情况

方法任务结果为”成功“,不需要主动设置

自主设置任务结果

  • 设置任务结果为失败:XxlJobHelper.handleFail
  • 设置任务结果成功:handleSuccess

14.调度中心集群部署

图示

在这里插入图片描述

执行器配置调度中心集群

在这里插入图片描述

15.任务分片

需求

  • 有一个任务需要处理100w条数据,每条数据的业务逻辑处理要0.1s
  • 对于普通任务来说,只有一个线程来处理,可能需要10万秒才能处理完,业务则严重收到影响
  • 案例:双十一大促,给1000万用户发营销短信

什么是分片任务

执行器集群部署时,任务路由策略选择”分片广播”情况下,一次任务调度将会广播触发对应集群中所有执行器执行一次任务,同时系统自动传递分片参数;可根据分片参数开发分片任务

“分片广播” 以执行器为维度进行分片,支持动态扩容执行器集群从而动态增加分片数量,协同进行业务处理;在进行大数据量业务操作时可显著提升任务处理能力和速度

Java语言任务获取分片参数方式

// 可参考Sample示例执行器中的示例任务"ShardingJobHandler"了解试用 
int shardIndex = XxlJobHelper.getShardIndex();
int shardTotal = XxlJobHelper.getShardTotal();

脚本语言任务获取分片参数方式

// 脚本任务入参固定为三个,依次为:任务传参、分片序号、分片总数。以Shell模式任务为例,获取分片参数代码如下
echo "分片序号 index = $2"
echo "分片总数 total = $3"

分片参数说明

  • index:当前分片序号(从0开始),执行器集群列表中当前执行器的序号
  • total:总分片数,执行器集群的总机器数量

应用场景

  • 分片任务场景:10个执行器的集群来处理10w条数据,每台机器只需要处理1w条数据,耗时降低10倍
  • 广播任务场景:广播执行器机器运行shell脚本、广播集群节点进行缓存更新等

16.访问令牌

介绍

为提升系统安全性,调度中心和执行器进行安全性校验,双方AccessToken匹配才允许通讯

设置方式

调度中心和执行器,可通过配置项 “xxl.job.accessToken” 进行AccessToken的设置

正常通讯的两种情况

调度中心和执行器,如果需要正常通讯,只有两种设置;

  • 调度中心和执行器,均不设置AccessToken;关闭安全性校验
  • 调度中心和执行器,设置了相同的AccessToken

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/422415.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用ffmpeg调整视频中音频采样率及声道

1 原始视频信息 通过ffmpeg -i命令查看视频基本信息 ffmpeg -i example2.mp4 ffmpeg version 6.1-essentials_build-www.gyan.dev Copyright (c) 2000-2023 the FFmpeg developersbuilt with gcc 12.2.0 (Rev10, Built by MSYS2 project)configuration: --enable-gpl --enable…

Kafka(三)【Broker 存储】

目录 前言 Kafka Broker 1、工作流程 1.1、Zookeeper 存储的 Kafka 信息 1.2、Kafka Broker 的总体工作流程 1.3、Broke 重要参数 2、Kafka 副本 2.1、副本基本信息 2.2、Keader 选举流程 2.3、Leader 和 Follower 的故障处理细节 Follower 故障 Leader 故障&#x…

每日一题——LeetCode1299.将每个元素替换为右侧最大元素

方法一 个人方法&#xff1a; 题目意思就是求在i1;i的循环条件下&#xff0c;arr[i]-arr[arr.length-1]的最大值分别为多少&#xff0c;最后一项默认为-1 用slice方法可以每次把数组第一位去除&#xff0c;得到求最大值的目标数组 Math的max方法可以直接返回数组里的最大值 …

<C++>STL->list

list的介绍 list list是一个类模板&#xff0c;第一个模板参数为存储数据类型&#xff1b;第二个模板参数为空间适配器list是一个可以在常数时间内完成任意位置的插入和删除的顺序容器。list容器是以双链表的形式实现的&#xff1b;双链表可以将其包含的每个元素存储在不同且…

批量转换:速度与质量的完美结合

你是否曾经遇到过需要批量转换上千条视频格式的挑战&#xff1f;这种任务不仅耗时&#xff0c;而且需要专业的视频处理技术。那么&#xff0c;有没有一种简单而高效的方法来完成这个任务呢&#xff1f;答案是肯定的。接下来&#xff0c;我将为你介绍一种快速、稳定的一分钟批量…

VMware workstation平台下配置Fedora-Server-39-1.5虚拟机网络

VMware workstation平台下配置Fedora-Server-39-1.5虚拟机网络 Fedora包含的软件以自由及开放源码许可来发布&#xff0c;并旨在成为该技术领域的领先者。Fedora在专注创新、抢先集成新技术、与上游Linux社区紧密工作方面拥有良好名声。该文档适用于在VMware workstation平台下…

meshgrid contour contourf

meshgrid contour contourf 参考video: https://www.bilibili.com/video/BV1qW411A775/?spm_id_from333.337.search-card.all.click&vd_sourced171c31a396363b8ea8c0e92a59cee6b 官方文档: https://matplotlib.org/stable/api/_as_gen/matplotlib.pyplot.contourf.html#ma…

网络要素服务(WFS)详解

文章目录 1. 概述2. GetCapabilities3. DescribeFeatureType4. GetFeature4.1 Get访问方式4.2 Post访问方式 5. Transaction5.1 Insert5.2 Replace5.3 Update5.4 Delete 6 注意事项 1. 概述 前置文章&#xff1a; 地图服务器GeoServer的安装与配置 GeoServer发布地图服务&#…

Postman如何做接口测试:如何导入 swagger 接口文档

&#x1f525; 交流讨论&#xff1a;欢迎加入我们一起学习&#xff01; &#x1f525; 资源分享&#xff1a;耗时200小时精选的「软件测试」资料包 &#x1f525; 教程推荐&#xff1a;火遍全网的《软件测试》教程 &#x1f4e2;欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1…

透明拼接屏在汽车领域的应用

随着科技的进步&#xff0c;透明拼接屏作为一种新型的显示技术&#xff0c;在汽车领域的应用越来越广泛。尼伽小编将围绕透明拼接屏在汽车本身、4S店、展会、工厂等方面的应用进行深入探讨&#xff0c;并展望未来的设计方向。 一、透明拼接屏在汽车本身的应用 车窗显示&#x…

Unity工程没有创建.sln文件,导致打开C#文件无法打开解决方案

最近又开始折腾些Unity的小项目&#xff0c;重新遇到一些常见的小问题 点击报错文件 却没有打开文件 于是查看了下打开Window->Package Manager 选择Unity Registry 搜索Visual Studio Editor&#xff0c;发现并没有安装 同理&#xff0c;也可以安装VSCode的插件 问题解决了…

【BBuf的CUDA笔记】十三,OpenAI Triton 入门笔记一

0x0. 前言 2023年很多mlsys工作都是基于Triton来完成或者提供了Triton实现版本&#xff0c;比如现在令人熟知的FlashAttention&#xff0c;大模型推理框架lightllm&#xff0c;diffusion第三方加速库stable-fast等灯&#xff0c;以及很多mlsys的paper也开始使用Triton来实现比…