Apollo功能及原理详解

前言

在我们公司,配置中心采用的是携程开源的Apollo。由于我之前只接触过Nacos,因此决定记录下我的学习过程。

Apollo工作原理

apollo_yl

模块介绍

以下是Apollo的架构概览,我们将从底层向上逐层解析:

  • ConfigDB:负责存储配置数据。
  • Config Service:提供配置读取和推送服务,服务于Apollo客户端,支持多实例,需要在Eureka中注册以保持服务心跳。
  • Admin Service:提供配置修改和发布功能,服务于Apollo Portal(管理界面),同样支持多实例,并在Eureka中注册。
  • Eureka:提供服务注册与发现功能,目前为了简化部署,Eureka与Config Service共存于同一JVM进程。
  • Meta Server:封装Eureka的服务发现接口。
  • Client:通过域名访问Meta Server获取Config Service服务列表(IP+Port),然后直接通过IP+Port访问服务,Client端实现负载均衡和错误重试。
  • Portal:通过域名访问Meta Server获取Admin Service服务列表(IP+Port),直接通过IP+Port访问服务,Portal端同样实现负载均衡和错误重试。

执行流程

  1. Apollo启动时,Config/Admin Service会自动向Eureka服务注册中心注册,并定期发送心跳以保持连接。
  2. Apollo Client和Portal通过配置的Meta Server域名,通过软件负载均衡器分配到特定的Meta Server。
  3. Meta Server作为Eureka Client,从Eureka获取Config Service和Admin Service的服务信息。
  4. 若Meta Server获取Config Service和Admin Service(IP+Port)失败,将进行重试。
  5. 成功获取服务信息后,Apollo Client通过Config Service为应用提供配置获取和实时更新功能;Apollo Portal管理端通过Admin Service提供配置的新增、修改和发布功能。

基本概念

  • application (应用)
    实际使用配置的应用,Apollo客户端在运行时需要识别当前应用,以便获取相应的配置。关键标识:appId。
  • environment (环境)
    配置所对应的环境,Apollo客户端在运行时需要识别当前应用所处的环境,以获取正确的配置。关键标识:env。
  • cluster (集群)
    应用下不同实例的分组,例如,可以将上海机房的应用实例分为一个集群,北京机房的应用实例分为另一个集群。关键标识:cluster。
  • namespace (命名空间)
    应用下不同配置的分组,可以将namespace视作文件,不同类型的配置存放于不同的文件中,例如数据库配置文件、RPC配置文件、应用自身的配置文件等。关键标识:namespaces。
  • 关系图如下:
    apollo_gxt

项目管理

部门管理

Apollo默认有两个部门。若需添加新部门,可在系统参数中进行修改。进入系统参数页面,输入key查询现有的部门设置:organizations。
apollo_bumen
修改value值以添加新部门,例如添加一个微服务部门:

[{"orgId":"TEST1","orgName":"样例部门1"},{"orgId":"TEST2","orgName":"样例部门2"},{"orgId":"micro_service","orgName":"微服务部门"}]

创建项目

  1. 打开Apollo主页,点击“创建应用”:
    apollo_chuangjian
  2. 输入相关信息,包括部门、应用AppId、应用名称和应用负责人:
    apollo_yingyongxinxi
  3. 授予用户管理服务权限,点击“授权”:
    ![apollo_shouquan](https://pic.it1024doc.com/cnblogs/202412/4046acd5a7d01bc73518ea6ca

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/4275.html

(0)
LomuLomu
上一篇 2024 年 12 月 24 日
下一篇 2024 年 12 月 24 日

相关推荐

  • Python在多个Excel文件中找出缺失数据行数多的文件

    本文介绍基于Python 语言,针对一个文件夹 下大量的Excel 表格文件,基于其中每一个文件 内、某一列数据 的特征,对其加以筛选,并将符合要求 与不符合要求 的文件分别复制到另外两个新的文件夹 中的方法。 首先,我们来明确一下本文的具体需求。现有一个文件夹,其中有大量的Excel 表格文件(在本文中我们就以csv格式的文件为例);如下图所示。 其中,每…

    2025 年 1 月 13 日
    30500
  • 永久有效的IDEA激活破解教程(2024亲测有效!)

    【永久启用】IDEA 2024.1.2 完备激活指南:配有验证激活码与工具 IntelliJ IDEA 是一款前沿的 Java 集成开发环境,广泛认为是顶级的 Java 工具之一。这篇文章将指导您如何利用脚本来免费激活 IDEA 和整个 Jetbrains 工具套件,适用于 2021 年及之后的版本,包括最新版。 安装 IntelliJ IDEA 您可以从 …

    未分类 2024 年 7 月 10 日
    8.4K00
  • Nginx HttpHeader增加几个关键的安全选项

    在面对德勤等专业渗透测试(Pentest)的场景时,为了确保网站的安全性并顺利通过严格的安全审查,对这些安全头部配置进行精细化和专业化的调整是至关重要的。 以下是对每个选项的详细建议以及设置值的说明: 1. Strict-Transport-Security (HSTS) 这一策略确保所有通信都通过HTTPS进行,并防止降级攻击。 推荐值: add_head…

    未分类 2024 年 12 月 24 日
    48100
  • 常见的图形库对比 Echarts Highcharts AntV

    图形库 图形库 特点 图表类型 适用场景 依赖项 官网/文档 ECharts 功能丰富,支持大规模数据,交互性强 折线图、柱状图、饼图、地图、雷达图、散点图、热力图等 复杂数据可视化 无 https://echarts.apache.org/ Chart.js 简单易用,轻量级,支持响应式设计 折线图、柱状图、饼图、雷达图、散点图等 简单图表,快速开发 无 …

    未分类 2025 年 1 月 13 日
    36700
  • JavaScript 中通过Array.sort() 实现多字段排序、排序稳定性、随机排序洗牌算法、优化排序性能,JS中排序算法的使用详解(附实际应用代码)

    目录 JavaScript 中通过Array.sort() 实现多字段排序、排序稳定性、随机排序洗牌算法、优化排序性能,JS中排序算法的使用详解(附实际应用代码) 一、为什么要使用Array.sort() Array.sort() 是 JavaScript 提供的一个内置数组排序方法。它不仅仅是一个简单的升序或降序排列工具,更是一种灵活的排序逻辑实现方式。通…

    未分类 2024 年 12 月 28 日
    40500

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信