Apollo的总体架构

Apollo的使用架构

Apollo的不同维度的配置分类

下面按照生效顺序

  1. Application
    在springboot的application.property定义appid这个key的value,标识该类型的应用。

  2. Environment

    • DEV(开发环境)
    • FAT(功能测试)
    • UAT(验收测试)
    • PRO(生产环境)
  3. Cluster(集群)

  4. Namespace(命名空间)
    其实就是某个应用的不同配置文件

Springboot使用apollo时的配置

# apollo配置,需要先创建一个应用,然后再创建这个应用相关的配置信息
# 指定apollo上面对应的应用id,程序会根据这个id去找到apollo上面对应的应用的配置
app.id: middleend-product
apollo:#指定对应的集群cluster: local#apollo的配置中心地址meta:  http://dev-config.aeonbuy.combootstrap:#在应用启动阶段是否向Spring容器注入被托管的properties文件配置信息enabled: true#指定要加载的命名空间namespaces: application,common-ms,common-excel,common-exception,autheagerLoad:#将Apollo配置加载提到初始化日志系统之前enabled: true

上面的配置中就差 Environment没有了,Environment的配置方式如下:

常用API

Config config = ConfigService.getAppConfig();

当应用使用上面的语句获取配置时,我们称之为获取应用自身的配置,也就是应用自身的application namespace的配置

  1. 首先查找运行时cluster的配置(通过apollo.cluster指定)
  2. 如果没有找到,则查找数据中心cluster的配置
  3. 如果还是没有找到,则返回默认cluster的配置


数据中心是机器上的配置(server.properties中的idc属性)指定的
所以如果应用部署在A数据中心,但是用户没有在Apollo创建cluster,那么获取的配置就是默认cluster(default)的。

如果应用部署在A数据中心,同时在运行时指定了SomeCluster,但是没有在Apollo创建cluster,那么获取的配置就是A数据中心cluster的配置,如果A数据中心cluster没有配置的话,那么获取的配置就是默认cluster(default)的。
Apollo客户端会把从服务端获取到的配置在本地文件系统缓存一份,当去服务器读取配置失败时,会使用本地缓存的。

Mac/Linux: /opt/data/{appId}/config-cacheWindows: C:\opt\data{appId}\config-cache
Config pubConfig = ConfigService.getConfig("xxxxxx");

获取指定 namespace的配置

NameSpace的详解

  1. 什么是Namespace?
    Namespace是配置项的集合,类似于一个配置文件的概念。

  2. 什么是“application”的Namespace?
    Apollo在创建项目的时候,都会默认创建一个“application”的Namespace。顾名思义,“application”是给应用自身使用的,
    熟悉Spring Boot的同学都知道,Spring Boot项目都有一个默认配置文件application.yml。在这里application.yml就等同于“application”的Namespace。
    对于90%的应用来说,“application”的Namespace已经满足日常配置使用场景了。

客户端获取“application” Namespace的代码如下:
Config config = ConfigService.getAppConfig();
客户端获取非“application” Namespace的代码如下:
Config config = ConfigService.getConfig(namespaceName);
3. Namespace的格式有哪些?
配置文件有多种格式,例如:properties、xml、yml、yaml、json等。同样Namespace也具有这些格式。
在Portal UI中可以看到“application”的Namespace上有一个“properties”标签,表明“application”是properties格式的。

注:非properties格式的namespace,在客户端使用时需要调用ConfigService.getConfigFile(String namespace, ConfigFileFormat configFileFormat)来获取,
如果使用Http接口直接调用时,对应的namespace参数需要传入namespace的名字加上后缀名,如datasources.json。

  1. Namespace的获取权限分类
    Namespace的获取权限分为两种:

private (私有的)
public (公共的)
这里的获取权限是相对于Apollo客户端来说的。

4.1 private权限
private权限的Namespace,只能被所属的应用获取到。一个应用尝试获取其它应用private的Namespace,Apollo会报“404”异常。

4.2 public权限
public权限的Namespace,能被任何应用获取。

  1. Namespace的类型
    Namespace类型有三种:

私有类型
公共类型
关联类型(继承类型)
5.1 私有类型
私有类型的Namespace具有private权限。例如上文提到的“application” Namespace就是私有类型。

5.2 公共类型
5.2.1 含义
公共类型的Namespace具有public权限。公共类型的Namespace相当于游离于应用之外的配置,且通过Namespace的名称去标识公共Namespace,
所以公共的Namespace的名称必须全局唯一。

5.2.2 使用场景
部门级别共享的配置
小组级别共享的配置
几个项目之间共享的配置
中间件客户端的配置
5.3 关联类型
5.3.1 含义
关联类型又可称为继承类型,关联类型具有private权限。关联类型的Namespace继承于公共类型的Namespace,用于覆盖公共Namespace的某些配置。
例如公共的Namespace有两个配置项

k1 = v1
k2 = v2
然后应用A有一个关联类型的Namespace关联了此公共Namespace,且覆盖了配置项k1,新值为v3。那么在应用A实际运行时,获取到的公共Namespace的配置为:

k1 = v3
k2 = v2
5.3.2 使用场景
举一个实际使用的场景。假设RPC框架的配置(如:timeout)有以下要求:

提供一份全公司默认的配置且可动态调整
RPC客户端项目可以自定义某些配置项且可动态调整
如果把以上两点要求去掉“动态调整”,那么做法很简单。在rpc-client.jar包里有一份配置文件,每次修改配置文件然后重新发一个版本的jar包即可。同理,客户端项目修改配置也是如此。
如果只支持客户端项目可动态调整配置。客户端项目可以在Apollo “application” Namespace上配置一些配置项。在初始化service的时候,从Apollo上读取配置即可。这样做的坏处就是,每个项目都要自定义一些key,不统一。
那么如何完美支持以上需求呢?答案就是结合使用Apollo的公共类型的Namespace和关联类型的Namespace。RPC团队在Apollo上维护一个叫“rpc-client”的公共Namespace,
在“rpc-client” Namespace上配置默认的参数值。rpc-client.jar里的代码读取“rpc-client”Namespace的配置即可。
如果需要调整默认的配置,只需要修改公共类型“rpc-client” Namespace的配置。
如果客户端项目想要自定义或动态修改某些配置项,只需要在Apollo 自己项目下关联“rpc-client”,
就能创建关联类型“rpc-client”的Namespace。然后在关联类型“rpc-client”的Namespace下修改配置项即可。
这里有一点需要指出的,那就是rpc-client.jar是在应用容器里运行的,所以rpc-client获取到的“rpc-client”
Namespace的配置是应用的关联类型的Namespace加上公共类型的Namespace。
5.4 例子
如下图所示,有三个应用:应用A、应用B、应用C。

应用A有两个私有类型的Namespace:application和NS-Private,以及一个关联类型的Namespace:NS-Public。
应用B有一个私有类型的Namespace:application,以及一个公共类型的Namespace:NS-Public。
应用C只有一个私有类型的Namespace:application
Namespace例子

5.4.1 应用A获取Apollo配置
//application
Config appConfig = ConfigService.getAppConfig();
appConfig.getProperty(“k1”, null); // k1 = v11
appConfig.getProperty(“k2”, null); // k2 = v21

//NS-Private
Config privateConfig = ConfigService.getConfig(“NS-Private”);
privateConfig.getProperty(“k1”, null); // k1 = v3
privateConfig.getProperty(“k3”, null); // k3 = v4

//NS-Public,覆盖公共类型配置的情况,k4被覆盖
Config publicConfig = ConfigService.getConfig(“NS-Public”);
publicConfig.getProperty(“k4”, null); // k4 = v6 cover
publicConfig.getProperty(“k6”, null); // k6 = v6
publicConfig.getProperty(“k7”, null); // k7 = v7
5.4.2 应用B获取Apollo配置
//application
Config appConfig = ConfigService.getAppConfig();
appConfig.getProperty(“k1”, null); // k1 = v12
appConfig.getProperty(“k2”, null); // k2 = null
appConfig.getProperty(“k3”, null); // k3 = v32

//NS-Private,由于没有NS-Private Namespace 所以获取到default value
Config privateConfig = ConfigService.getConfig(“NS-Private”);
privateConfig.getProperty(“k1”, “default value”);

//NS-Public
Config publicConfig = ConfigService.getConfig(“NS-Public”);
publicConfig.getProperty(“k4”, null); // k4 = v5
publicConfig.getProperty(“k6”, null); // k6 = v6
publicConfig.getProperty(“k7”, null); // k7 = v7
5.4.3 应用C获取Apollo配置
//application
Config appConfig = ConfigService.getAppConfig();
appConfig.getProperty(“k1”, null); // k1 = v12
appConfig.getProperty(“k2”, null); // k2 = null
appConfig.getProperty(“k3”, null); // k3 = v33

//NS-Private,由于没有NS-Private Namespace 所以获取到default value
Config privateConfig = ConfigService.getConfig(“NS-Private”);
privateConfig.getProperty(“k1”, “default value”);

//NS-Public,公共类型的Namespace,任何项目都可以获取到
Config publicConfig = ConfigService.getConfig(“NS-Public”);
publicConfig.getProperty(“k4”, null); // k4 = v5
publicConfig.getProperty(“k6”, null); // k6 = v6
publicConfig.getProperty(“k7”, null); // k7 = v7
5.4.4 ChangeListener
以上代码例子中可以看到,在客户端Namespace映射成一个Config对象。Namespace配置变更的监听器是注册在Config对象上。

所以在应用A中监听application的Namespace代码如下:

Config appConfig = ConfigService.getAppConfig();
appConfig.addChangeListener(new ConfigChangeListener() {
public void onChange(ConfigChangeEvent changeEvent) {
//do something
}
})
在应用A中监听NS-Private的Namespace代码如下:

Config privateConfig = ConfigService.getConfig(“NS-Private”);
privateConfig.addChangeListener(new ConfigChangeListener() {
public void onChange(ConfigChangeEvent changeEvent) {
//do something
}
})
在应用A、应用B、应用C中监听NS-Public的Namespace代码如下:

Config publicConfig = ConfigService.getConfig(“NS-Public”);
publicConfig.addChangeListener(new ConfigChangeListener() {
public void onChange(ConfigChangeEvent changeEvent) {
//do something
}
})

Apollo 配置详解相关推荐

  1. elasticsearch-.yml(中文配置详解)

    此elasticsearch-.yml配置文件,是在$ES_HOME/config/下 elasticsearch-.yml(中文配置详解) # ======================== El ...

  2. (ASA) Cisco Web ××× 配置详解 [三部曲之一]

    (ASA) Cisco Web ××× 配置详解 [三部曲之一] 注意:本文仅对Web×××特性和配置作介绍,不包含SSL ×××配置,SSL ×××配置将在本版的后续文章中进行介绍.   首先,先来 ...

  3. mybatis 同名方法_MyBatis(四):xml配置详解

    目录 1.我们将 数据库的配置语句写在 db.properties 文件中 2.在 mybatis-configuration.xml 中加载db.properties文件并读取 通过源码我们可以分析 ...

  4. logback节点配置详解

    logback节点配置详解 一:根节点 <configuration></configuration> 属性 : debug : 默认为false ,设置为true时,将打印出 ...

  5. PM配置详解之一:企业结构

    1.维护计划工厂 功能说明 在公司结构中定义维护工厂(通常已经作为后勤工厂存在)和维护计划工厂(简称计划工厂). 维护工厂:设备所安装的位置,如某机组安装在合营公司,那么合营公司就是此机组的维护工厂, ...

  6. 转 Log4j.properties配置详解

    一.Log4j简介 Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出.综合使 ...

  7. Iptables防火墙配置详解

    iptables防火墙配置详解 iptables简介 iptables是基于内核的防火墙,功能非常强大,iptables内置了filter,nat和mangle三张表. (1)filter表负责过滤数 ...

  8. spring之旅第四篇-注解配置详解

    spring之旅第四篇-注解配置详解 一.引言 最近因为找工作,导致很长时间没有更新,找工作的时候你会明白浪费的时间后面都是要还的,现在的每一点努力,将来也会给你回报的,但行好事,莫问前程!努力总不会 ...

  9. php-fpm 启动参数及重要配置详解

    2019独角兽企业重金招聘Python工程师标准>>> php-fpm 启动参数及重要配置详解 约定几个目录 /usr/local/php/sbin/php-fpm /usr/loc ...

最新文章

  1. 三层交换解决了VLAN之间的通信问题
  2. dd linux 尾部添加0_Linux文件目录命令整理Linux学习
  3. 链接 动态链接 静态链接
  4. jeecg中excel导出字段判空处理
  5. mysql获取后一天_mysql获取当前时间,前一天,后一天
  6. C#操作XML的完整例子——XmlDocument篇
  7. 【Pre-Training】XLNet:预训练最强,舍我其谁
  8. mysql-proxy实现读写分离
  9. 静态HTML网页设计作品 HTML5+CSS大作业——个人网页设计(7页)
  10. win7 计算机 地址栏扫描,Win7系统添加地址栏的两种方法
  11. 扫描服务Windows Image Acquisition(WIA)错误1068的解决办法
  12. oeasy教您玩转linux010105详细手册man
  13. 森林防火火灾漫延算法 火灾推演算法分析 火灾蔓延范围计算方法 森林火灾边界漫延计算方法
  14. php网上商城作业,商城主体作业
  15. 哈尔滨计算机职业学校赵梓琦,哈尔滨赛区复选晋级名单
  16. 电脑端微信可以打开微信小程序了
  17. 五十条经典的做人哲学
  18. 学院来信371:建立“可复制”+“可迭代”的投资系统
  19. hppt加密 java代码_Http Sampler扩展(加密处理)
  20. kubernetes挂载ceph rbd和cephfs

热门文章

  1. 企业微信接口开启收费模式,意在第三方生态健康发展
  2. 10进制数转化为16进制数
  3. 劳拉下棋python_Python数据及要求分析实战
  4. Linux中根目录的基本知识
  5. 错误集合--CRM项目
  6. akcms comment.php,AKCMS新春贺岁发布4.0.6版 新增优化众多功能
  7. “礼物”装点圣诞,海外网红营销如何在圣诞购物季出圈?
  8. Lodop指定纸张类型不生效问题
  9. 《思考的技术》读后感思维导图
  10. Linux操作系统实用技巧精彩汇集