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 日

相关推荐

  • 【Java 学习】面向程序的三大特性:封装、继承、多态

    引言 在面向对象编程的世界里,封装、继承和多态构成了核心的三大特性。本文将深入探讨这些概念,并通过Java代码示例来阐释它们的重要性和实际应用。 1. 封装 1.1 什么是封装呢? 封装是一种隐藏对象的内部状态和复杂性,只对外暴露有限接口的设计原则。就像我们日常使用的电子产品,它们将复杂的内部结构封装起来,只展示用户需要操作的部分。 在Java中,封装通过访…

    2024 年 12 月 27 日
    12900
  • Java内存泄漏问题的高效排查与优化指南

    目录导航1. 系统化诊断与优化框架2. 内存快照获取技术2.1 自动生成堆转储文件2.2 手动创建堆转储文件3. 专业分析工具应用3.1 内存分析工具MAT3.2 性能分析工具JProfiler3.3 企业级专用工具4. 深度排查内存泄漏4.1 内存差异对比分析4.2 可疑泄漏对象检测4.3 内存占用大户识别4.4 不可达对象追踪5. 问题确认与验证6. 代…

    2025 年 5 月 13 日
    7500
  • Linux安装Anaconda

    1、获取Anaconda安装包 首先,我们需要访问Anaconda的官方网站,以获取适合您系统环境的安装包。您可以在以下链接找到所需的版本: Anaconda官方下载页面 下载完成后,请将安装文件传输至您的服务器。 2、Anaconda的安装步骤 步骤1:赋予执行权限 在终端中输入以下命令,以确保安装脚本具有执行权限: chmod 755 Anaconda3…

    2024 年 12 月 26 日
    25400
  • 深入解析 Spring AI 系列:以OpenAI与Moonshot案例为例寻找共同点

    今天,我们将重点探讨对接的业务逻辑。为了帮助大家更直观地掌握其中的规律性,我将通过对比OpenAI与《月之暗面》中的Moonshot两个案例来阐述这一点。通过这样的对比,大家可以更清晰地看到,这些对接业务的整体框架其实非常相似。换句话说,我们要做的工作只是其中的一小部分,但它同样是关键的一环。 好了,接下来我们就开始深入了解这个话题。 模型对接 我们首先需要…

    2025 年 1 月 12 日
    20700
  • 探秘荣昌卤鹅美食地图:基于Java与天地图的地理信息实践

    目录导航背景介绍1、网红效应带动地方美食热潮2、荣昌卤鹅产业布局解析3、技术赋能美食探索一、地理信息检索基础1、检索功能概述2、API接口详解二、实战荣昌卤鹅定位1、数据采集方案2、API请求实现3、参数配置技巧4、数据存储方案三、实践总结 背景介绍 1、网红效应带动地方美食热潮 近期,重庆荣昌卤鹅因一起跨文化交流事件意外走红。当地助农主播林某通过创意营销,…

    2025 年 5 月 13 日
    7400

发表回复

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

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

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

关注微信