Apollo配置中心有什么组件,组件有什么作用 ?

Apollo配置中心组件讲解_第1张图片

从编译出来的jar包展开来讲,或是说运行包来说,只有4个组件,分别是:

Portal

  1. 提供Web界面供用户管理配置
  2. 通过Meta Server获取Admin Service服务列表(IP+Port),通过IP+Port访问服务
  3. 在Portal侧做load balance、错误重试

Admin Service

  1. 提供配置管理接口
  2. 提供配置修改、发布等接口
  3. 接口服务对象为Portal

Config Service

  1. Config Service 包中包含了三个组件: config ,meta server,euraka
    a. Config 组件
    A. 提供配置获取接口
    B. 提供配置更新推送接口(基于Http long polling)
    i. 服务端使用Spring DeferredResult实现异步化,从而大大增加长连接数量
    ii. 目前使用的tomcat embed默认配置是最多10000个连接(可以调整),使用了4C8G的虚拟机实测可以支撑10000个连接,所以满足需求(一个应用实例只会发起一个长连接)。
    C. 接口服务对象为Apollo客户端

    b. Meta Server组件
    A. Portal通过域名访问Meta Server获取Admin Service服务列表(IP+Port)
    B. Client通过域名访问Meta Server获取Config Service服务列表(IP+Port)
    C. Meta Server从Eureka获取Config Service和Admin Service的服务信息,相当于是一个Eureka Client
    D. 增设一个Meta Server的角色主要是为了封装服务发现的细节,对Portal和Client而言,永远通过一个Http接口获取Admin Service和Config Service的服务信息,而不需要关心背后实际的服务注册和发现组件
    E. Meta Server只是一个逻辑角色,在部署时和Config Service是在一个JVM进程中的

    c. Eureka组件
    A. 基于Eureka和Spring Cloud Netflix提供服务注册和发现
    B. Config Service和Admin Service会向Eureka注册服务,并保持心跳
    C. 为了简单起见,目前Eureka在部署时和Config Service是在一个JVM进程中的(通过Spring Cloud Netflix)


Client

  1. Apollo提供的客户端程序,为应用提供配置获取、实时更新等功能
  2. 通过Meta Server获取Config Service服务列表(IP+Port),通过IP+Port访问服务
  3. 在Client侧做load balance、错误重试

如果从用户访问数据流的关系图,大概类似如下的结构:

Apollo配置中心组件讲解_第2张图片

基本机制流程如下:

  1. Config Service启动时候启动Config server,Meta server,Eureka三个服务 ,同时Config Server把自身注册到Eureka上面,并保持心跳。
  2. Admin Server 启动时,把自身注册到Eureka 上面,并保持心跳。
  3. Config Server,Admin Server都通过Meta Server连接Eureka,所以Meta Server相当于一个Eureka的客户端,提供功能接口。
  4. Portal 启动时候,通过Meta Server获取Admin Service 的列表(IP:PORT),同时通过软件实现LB,错误重试
  5. Client 客户端添加到开发项目中,项目启动后,客户端会通过Meta Server获取Config service的列表,并在客户端内部实现了LB,错误重试

如果理解了上面的组件以及数据流程,那么也应该明白如果要编译安装Apollo大概需要获得什么组件。参考上面的第一张图,那么编译后的Apollo组件应该有四个:Portal,Admin Service ,Config Server,Client 。