源码分析Elastic-Job前置篇二-基于Spring启动序列图与核心类图

简介: 本文主要目的:简单梳理了基于 Spring ElasticJob 的启动流程,从下文开始,将重点剖析 ElasticJob 的核心实现细节,例如选主、分片、失效转移机制等等。1、在Spring中使用Elastic-Job的示例如下:<job:simple id="areaSyncJob" cl...

本文主要目的:简单梳理了基于 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自定义命令空间与标签解析原理分析

a

  • JobScheduler:ElasticJob调度任务管理实例.

    • LiteJobConfiguration liteJobConfig:job配置文件。

      • CoordinatorRegistryCenter regCenter:分布式协调注册中心。
      • SchedulerFacade schedulerFacade:任务调度门面类。

        • JobFacade jobFacade:job门面类。
  • JobScheduleController
  1. job封装类,封装了quartz api,包括调度任务、重新调度任务、暂停任务、恢复任务、触发任务,是ElasticJob与Quartz的桥梁。

Spring 加载配置文件并创建调度任务

其时序图所图示:
b

  • 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所有事件监听管理器如图所示:
c

  • ElectionListenerManager:主节点选举监听管理器
  • ShardingListenerManager:分片监听管理器。
  • FailoverListenerManager:失效转移监听管理器。
  • MonitorExecutionListenerManager:幂等性监听管理器。
  • ShutdownListenerManager:运行实例关闭监听管理器。
  • TriggerListenerManager:作业触发监听管理器。
  • RescheduleListenerManager:重调度监听管理器。
  • GuaranteeListenerManager:保证分布式任务全部开始和结束状态监听管理器。

本文就到此为止,从下篇文章开始将重点介绍分布式调度任务所需要解决的问题的实现原理,例如如何选主、分片、失效转移等。

目录
相关文章
|
3月前
|
监控 Java 应用服务中间件
SpringBoot是如何简化Spring开发的,以及SpringBoot的特性以及源码分析
Spring Boot 通过简化配置、自动配置和嵌入式服务器等特性,大大简化了 Spring 应用的开发过程。它通过提供一系列 `starter` 依赖和开箱即用的默认配置,使开发者能够更专注于业务逻辑而非繁琐的配置。Spring Boot 的自动配置机制和强大的 Actuator 功能进一步提升了开发效率和应用的可维护性。通过对其源码的分析,可以更深入地理解其内部工作机制,从而更好地利用其特性进行开发。
87 6
|
4月前
|
设计模式 XML Java
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
本文详细介绍了Spring框架的核心功能,并通过手写自定义Spring框架的方式,深入理解了Spring的IOC(控制反转)和DI(依赖注入)功能,并且学会实际运用设计模式到真实开发中。
【23种设计模式·全精解析 | 自定义Spring框架篇】Spring核心源码分析+自定义Spring的IOC功能,依赖注入功能
|
5月前
|
监控 Java 应用服务中间件
Spring Boot整合Tomcat底层源码分析
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置和起步依赖等特性,大大简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是其与Tomcat的整合。
147 1
|
5月前
|
前端开发 Java Spring
Spring MVC源码分析之DispatcherServlet#getHandlerAdapter方法
`DispatcherServlet`的 `getHandlerAdapter`方法是Spring MVC处理请求的核心部分之一。它通过遍历预定义的 `HandlerAdapter`列表,找到适用于当前处理器的适配器,并调用适配器执行具体的处理逻辑。理解这个方法有助于深入了解Spring MVC的工作机制和扩展点。
59 0
|
5月前
|
前端开发 Java Spring
Spring MVC源码分析之DispatcherServlet#getHandlerAdapter方法
`DispatcherServlet`的 `getHandlerAdapter`方法是Spring MVC处理请求的核心部分之一。它通过遍历预定义的 `HandlerAdapter`列表,找到适用于当前处理器的适配器,并调用适配器执行具体的处理逻辑。理解这个方法有助于深入了解Spring MVC的工作机制和扩展点。
85 1
|
5月前
|
前端开发 Java Spring
Spring MVC源码分析之DispatcherServlet#getHandlerAdapter方法
`DispatcherServlet`的 `getHandlerAdapter`方法是Spring MVC处理请求的核心部分之一。它通过遍历预定义的 `HandlerAdapter`列表,找到适用于当前处理器的适配器,并调用适配器执行具体的处理逻辑。理解这个方法有助于深入了解Spring MVC的工作机制和扩展点。
69 1
|
6月前
|
缓存 JavaScript Java
Spring之FactoryBean的处理底层源码分析
本文介绍了Spring框架中FactoryBean的重要作用及其使用方法。通过一个简单的示例展示了如何通过FactoryBean返回一个User对象,并解释了在调用`getBean()`方法时,传入名称前添加`&`符号会改变返回对象类型的原因。进一步深入源码分析,详细说明了`getBean()`方法内部对FactoryBean的处理逻辑,解释了为何添加`&`符号会导致不同的行为。最后,通过具体代码片段展示了这一过程的关键步骤。
Spring之FactoryBean的处理底层源码分析
|
10月前
|
存储 安全 Java
Spring Security 6.x OAuth2登录认证源码分析
上一篇介绍了Spring Security框架中身份认证的架构设计,本篇就OAuth2客户端登录认证的实现源码做一些分析。
436 2
Spring Security 6.x OAuth2登录认证源码分析
|
10月前
|
存储 Java Spring
Spring IOC 源码分析之深入理解 IOC
Spring IOC 源码分析之深入理解 IOC
305 2
|
11月前
|
Dubbo Java 应用服务中间件
Dubbo 第四节: Spring与Dubbo整合原理与源码分析
DubboConfigConfigurationRegistrar的主要作⽤就是对propties⽂件进⾏解析并根据不同的配置项项⽣成对应类型的Bean对象。
201 0