本文主要目的:简单梳理了基于 Spring ElasticJob 的启动流程,从下文开始,将重点剖析 ElasticJob 的核心实现细节,例如选主、分片、失效转移机制等等。
1、在Spring中使用Elastic-Job的示例如下:
<job:simple id="areaSyncJob" class="full class path"
registry-center-ref="regCenter" cron="${elastic.exp.job.gisAMapArea.cron}"
disabled="${elastic.exp.job.gisAMapArea.disabled}"
sharding-total-count="${elastic.exp.job.areaSyncJob.shardingtotalcount}"
sharding-item-parameters="${elastic.exp.job.areaSyncJob.shardingitemparameters}"
overwrite="true" job-parameter="1" monitor-execution="true"
description="高德行政区域数据同步" event-trace-rdb-data-source="dataSource" />
从上篇中我们知道,该标签的解析类为:SimpleJobBeanDefinitionParser,最终会构建SpringJobScheduler 实例,并在初始化实例后调用 init 方法,开始 Job 任务的生命周期(启动、运行、调度)。
2、Spring自定义命令空间与标签解析原理分析
- JobScheduler:ElasticJob调度任务管理实例.
- LiteJobConfiguration liteJobConfig:job配置文件。
- CoordinatorRegistryCenter regCenter:分布式协调注册中心。
- SchedulerFacade schedulerFacade:任务调度门面类。
- JobFacade jobFacade:job门面类。
- JobScheduleController
quartz job封装类,封装了quartz api,包括调度任务、重新调度任务、暂停任务、恢复任务、触发任务,是ElasticJob与Quartz的桥梁。
Spring 加载配置文件并创建调度任务
其时序图所图示:
- AbstractJobBeanDefinitionParse调用parseInternal()方法解析< job:simpleJob/>标签。
- 在SimpleJobBeanDefinitionParser类中调用SprinJobScheduler的init()方法。
- 第二步实际调用的是SpringJobScheduler的父类JobScheduler的init()方法。
- 利用StdSchedulerFactory创建Quartz的调度器Scheduler。
- 创建Quartz的JobDetail示例。
- 根据Scheduler、JobDetail、jobname创建JobScheduleController实例。
- 注册启动信息,ElasticJob的任务服务器的启动流程就在这里定义,下文详细分析。
- 启动调度任务,受Quartz框架的定时调度。
4、作业服务器启动流程
上面第7步,ElasticJob注册启动信息,其源码如下:
SchedulerFacade#registerStartUpInfo:
/**
* 注册作业启动信息.
*
* @param enabled 作业是否启用
*/
public void registerStartUpInfo(final boolean enabled) {
listenerManager.startAllListeners();
leaderService.electLeader();
serverService.persistOnline(enabled);
instanceService.persistOnline();
shardingService.setReshardingFlag();
monitorService.listen();
if (!reconcileService.isRunning()) {
reconcileService.startAsync();
}
}
- 启动ElasticJob所有zk事件监听管理器。
- 选主。
- 注册并持久化作业服务器信息。
- 注册并持久化作业运行实例信息。
- 设置是否需要重新分片。
- 启动调解分布式作业不一致状态服务。
ElasticJob所有事件监听管理器如图所示:
- ElectionListenerManager:主节点选举监听管理器
- ShardingListenerManager:分片监听管理器。
- FailoverListenerManager:失效转移监听管理器。
- MonitorExecutionListenerManager:幂等性监听管理器。
- ShutdownListenerManager:运行实例关闭监听管理器。
- TriggerListenerManager:作业触发监听管理器。
- RescheduleListenerManager:重调度监听管理器。
- GuaranteeListenerManager:保证分布式任务全部开始和结束状态监听管理器。
本文就到此为止,从下篇文章开始将重点介绍分布式调度任务所需要解决的问题的实现原理,例如如何选主、分片、失效转移等。
见文如面,我是威哥,热衷于成体系剖析JAVA主流中间件,关注公众号『中间件兴趣圈』,回复专栏可获取成体系专栏导航,回复资料可以获取笔者的学习思维导图。