xxl-job 分布式调度学习笔记

1.概述

1.1什么是任务调度

业务场景:

  • 上午10点,下午2点发放一批优惠券
  • 银行系统需要在信用卡到期还款日的前三天进行短信提醒

  • 财务系统需要在每天凌晨0:10分结算前一天的财务数据,统计汇总

  • 不同系统间的数据需要保持一致,这时候需要执行数据同步

任务调度是为了自动完成特定的任务,在约定的特定时刻去执行任务的过程。

1.2 为什么需要分布式调度

使用Spring中提供的注解@Scheduled,也能实现调度的功能

在业务类中方法中贴上这个注解,然后在启动类上贴上`@EnableScheduling`注解

@Scheduled(cron = "0/20 * * * * ? ")public void doWork(){//doSomething   }

感觉SprintBoot提供的注解可以完成任务调度的功能,好像已经完美的解决了问题,为什么还需要分布式调度呢?

主要以下几个原因:

  • 高可用:单机版的定式任务调度只能在一台机器上运行,如果程序或者系统出现异常就会导致功能不可用。
  • 防止重复执行:在单机模式下,定时任务是没什么问题的。但当我们部署了多台服务,同时又每台服务又有定时任务时,若不进行合理的控制在同一时间,只有一个定时任务启动执行,这时,定时执行的结果就可能存在混乱和错误了。
  • 单机处理极限:原本1分钟内需要处理1万个订单,但是现在需要1分钟内处理10万个订单;原来一个统计需要1小时,现在业务方需要10分钟就统计出来。你也许会说,你也可以多线程、单机多进程处理。的确,多线程并行处理可以提高单位时间的处理效率,但是单机能力毕竟有限(主要是CPU、内存和磁盘),始终会有单机处理不过来的情况。

1.3 XXL-JOB介绍

XXL-JOB是大众点评的分布式调度平台,是一个轻量级的分布式任务调度平台,其核心设计目标是:开发迅速、学习简单、轻量级、易扩展。

大众点评目前已经接入xxl-job任务调度平台,该系统已经调度100万次,表现优异。

目前已有多家公司接入xxl-job,包括比较知名的大众点评,京东,优信二手车,360金融 (360),联想集团 (联想),易信 (网易)等等

官网地址:https://www.xuxueli.com/xxl-job/

系统架构图:

设计思想:

  • 将调度行为抽象成“调度中心”公共平台,而平台自身并不承担业务逻辑,调度中心负责发起调度请求
  • 将任务抽象成分散的JobHandler,交由“执行器”统一管理,执行器负责接收调度请求并执行对应的JobHandler中的业务逻辑

因此,调度和任务两部分可以相互解耦,提供系统整体的稳定性和扩展性。

链路: 调度中心 ----> 执行器 -----> JobHandler

2.快速入门

2.1 下载源码

源码下载地址:

  • https://github.com/xuxueli/xxl-job
  • https://gitee.com/xuxueli0323/xxl-job

2.1 初始化调度数据库

下载源码后,解压源码,sql文件位置:

/xxl-job/doc/db/tables_xxl_job.sql

默认的database库名: xxl_job

数据库中表介绍:

  • xxl_job_group:执行器信息表,维护任务执行器信息;
  • xxl_job_info:用于保存XXL-JOB调度任务的扩展信息,如任务分组、任务名、机器地址、执行器、执行入参和报警邮件等等;
  • xxl_job_lock:任务调度锁表;
  • 调度日志表: 用于保存XXL-JOB任务调度的历史信息,如调度结果、执行结果、调度入参、调度机器和执行器等等;
  • xxl_job_log_report:调度日志报表:用户存储XXL-JOB任务调度日志的报表,调度中心报表功能页面会用到;
  • xxl_job_logglue:任务GLUE日志:用于保存GLUE更新历史,用于支持GLUE的版本回溯功能;
  • xxl_job_registry:执行器注册表,维护在线的执行器和调度中心机器地址信息;
  • xxl_job_user:系统用户表;
  数据库中表介绍:- 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_registry:执行器注册表,维护在线的执行器和调度中心机器地址信息;- xxl_job_user:系统用户表;

2.2 编译源码

2.2.1 源码目录解释:

  1. doc :文档资料
  2. xxl-job-admin :调度中心,项目源码
  3. xxl-job-core :公共Jar依赖
  4. xxl-job-executor-samples :执行器,Sample示例项目(大家可以在该项目上进行开发,也可以将现有项目改造生成执行器项目)

2.2.2 源码需要改动的点:

  1. application.properties修改数据库连接信息,用户信息和密码
    jdbc:mysql://127.0.0.1:3306/xxl-job2
  2. logback.xml修改日志路径信息:/data/applogs/xxl-job/xxl-job-admin.log-->./data/applogs/xxl-job/xxl-job-admin.log

2.2.3 启动成功后,访问:http://localhost:8080/xxl-job-admin/

2.3 配置部署调度中心

2.3.1 调度中心配置
2.3.2 部署项目

2.4 配置部署执行器项目

2.4.1 添加Maven依赖
2.4.2 执行器配置
2.4.3 添加执行器配置
2.4.4 添加任务处理类

2.5 运行HelloWorld程序

2.5.1 任务配置&触发执行
2.5.2 查看日志

2.6 GLUE模式(Java)

2.7 执行器集群

2.7.1 集群环境搭建
2.7.2 调度路由算法讲解

3. 分片功能讲解

3.1 案例需求讲解

3.1.1 初始化数据
3.1.2 集成Druid&MyBatis
3.1.3 业务功能实现

3.2 分片概念讲解

3.3 案例改造成任务分片

4. 项目集成XXL-JOB

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

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

相关文章

构建健康中国:医保支付购药系统的技术实现

在数字化时代,医保支付购药系统的技术实现成为医疗保障体系不可或缺的一环。通过整合医疗资源、优化服务流程,这一系统为患者提供了更便捷、高效的医疗服务。本文将深入探讨医保支付购药系统的技术架构与实现方法。 1. 技术架构概述 医保支付购药系统…

利用台阶仪测量薄膜厚度的方法和技巧

在薄膜制备过程中,薄膜厚度是一个至关重要的参数,直接影响薄膜的性能和应用。为了准确测量薄膜厚度,研究者广泛使用台阶仪,这是一种方便、直接、准确的测量方法。本文将介绍如何利用台阶仪进行薄膜厚度测量的方法和技巧。 选择合…

谷歌Chrome浏览器无法安装插件的解决方法

Google Chrome是一款由Google公司开发的网页浏览器,该浏览器基于其他开源软件撰写,包括WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。使用谷歌浏览器安装扩展插件的时候有时会遇到无法安装问题 解决…

微信小程序校园跑腿系统怎么做,如何做,要做多久

​ 在这个互联网快速发展、信息爆炸的时代,人人都离不开手机,每个人都忙于各种各样的事情,大学生也一样,有忙于学习,忙于考研,忙着赚学分,忙于参加社团,当然也有忙于打游戏的&#x…

maui中实现加载更多 RefreshView跟ListView(2)

一个类似商品例表的下拉效果&#xff1a; 代码 新增个类为商品商体类 public class ProductItem{public string ImageSource { get; set; }public string ProductName { get; set; }public string Price { get; set; }}界面代码&#xff1a; <?xml version"1.0&quo…

swing快速入门(十八)

注释很详细&#xff0c;直接上代码 上一篇 新增内容 1.给文本域添加TextListener&#xff0c;监听内容变化 2.给下拉选择框添加ItemListener&#xff0c;监听内容变化 import javax.swing.*; import java.awt.*; import java.awt.event.*;public class swing_test_14 {publ…

HamronyOS 自动化测试框架使用指南

概述 为支撑 HarmonyOS 操作系统的自动化测试活动开展&#xff0c;我们提供了支持 JS/TS 语言的单元及 UI 测试框架&#xff0c;支持开发者针对应用接口进行单元测试&#xff0c;并且可基于 UI 操作进行 UI 自动化脚本的编写。 本指南重点介绍自动化测试框架的主要功能&#x…

camel丢失请求body问题排查

项目组要和被收购的公司做接口对接&#xff0c;使用camel进行集成。在使用的过程当中&#xff0c;我们几个小伙伴都遇到了一个相同的问题&#xff1a;请求request body的内容失踪了。这里贴出有问题的路由配置&#xff1a; <?xml version"1.0" encoding"U…

高速口相关知识

一.不通系列fpga对高速口的叫法不一样&#xff1a; artix7——GTP kintex7——GTX virtex7——GTH 二.高速口的架构基本一致————4对rx/tx对1个时钟模块&#xff08;包含4个cpll1个Qpll&#xff09; 1&#xff1a;一个高速口【一个高速bank&#xff1a;&#xff08;eg&a…

ADB:获取坐标

命令&#xff1a; adb shell getevent | grep -e "0035" -e "0036" adb shell getevent -l | grep -e "0035" -e "0036" 这一条正确&#xff0c;但是&#xff0c;grep给过滤了&#xff0c;导致没有输出 getevent -c 10 //输出10条信息…

天猫数据分析-天猫查数据软件-11月天猫平台饮料市场品牌及店铺销量销额数据分析

今年以来&#xff0c;饮料是快消品行业中少数保持稳定增长的品类之一。 11月份&#xff0c;饮料市场同样呈现较好的增长态势。根据鲸参谋电商数据分析平台的相关数据显示&#xff0c;今年11月份&#xff0c;天猫平台上饮料市场的销量为2700万&#xff0c;环比增长约42%&#xf…

MLOps在极狐GitLab 的现状和前瞻

什么是 MLOps 首先我们可以这么定义机器学习&#xff08;Machine Learning&#xff09;&#xff1a;通过一组工具和算法&#xff0c;从给定数据集中提取信息以进行具有一定程度不确定性的预测&#xff0c;借助于这些预测增强用户体验或推动内部决策。 同一般的软件研发流程比…