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 日

相关推荐

  • PostgreSQL 的历史

    title: PostgreSQL 的历史date: 2024/12/23updated: 2024/12/23author: cmdragon excerpt:PostgreSQL 是一款功能强大且广泛使用的开源关系型数据库管理系统。其历史可以追溯到1986年,当时由加州大学伯克利分校的一个研究团队开发。文章将深入探讨 PostgreSQL 的起源、发展历…

    2025 年 1 月 1 日
    50400
  • java: JDK isn‘t specified for module ‘product-service‘问题解决

    目录 问题 解决方法 1.打开File->Project Structure… 2.将Project SDK修改为17 Oracle OpenJDK 17.0.12,并Apply,OK 问题 添加module后报错:java: JDK isn’t specified for module ‘product-service’ 查看pom.xml文件也添加了…

    2025 年 1 月 9 日
    42300
  • Java程序员必读的10本豆瓣高分经典书籍PDF

    要想成为一名优秀的Java程序员,不仅需要精通Java语言本身,还需要扎实的计算机基础、良好的编码习惯以及对软件开发全局的理解。掌握了这些基础知识,就像拥有了九阳神功和乾坤大挪移一样,再学习其它各门各派功夫直接手到擒来! 以下是从计算机基础、编程思想、Java语言、架构设计等方面精选的10本豆瓣高分经典书籍,它们能够帮助Java程序员全面提升编程能力和职业素…

    2025 年 1 月 15 日
    58000
  • Redis 爆高危漏洞,请速度修复。。

    大家好,我是R哥。 今天一早收到了腾讯云给我的【主机安全 】漏洞通知: 好家伙,大名鼎鼎的 Redis 爆高危漏洞了,R哥的题库「Java面试库」也用到了 Redis 来缓存面试题内容,所以这一下子就引起了我的警惕,赶紧看看什么鬼。 漏洞描述 下面是漏洞描述和修复说明: https://github.com/redis/redis/security/advi…

    2025 年 1 月 6 日
    45400
  • 如何做好软件架构师

    本文以个人视野聊下软件架构师的工作以及软件架构设计知识。做开发工作接近10年了,期间主要做Windows应用开发。在成熟的“华南区最大WPF团队”希沃白板呆了较长一段时间、后面从0到1构建Windows技术栈以及会议屏软件集,在软件设计这块自己成长了很多。之前整理过如何做好技术经理 – 唐宋元明清2188 – 博客园,这里梳理下自己的设计思维,算是自己阶段性…

    未分类 2025 年 1 月 14 日
    53500

发表回复

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

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

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

关注微信