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 编译源码
源码目录解释:
- doc :文档资料
- xxl-job-admin :调度中心,项目源码
- xxl-job-core :公共Jar依赖
- xxl-job-executor-samples :执行器,Sample示例项目(大家可以在该项目上进行开发,也可以将现有项目改造生成执行器项目)
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