前言

最近公司项目开始用微服务相关的技术设计apollo,自己也是初学者就边学边总结,部分内容来自官网,大牛请便。

1.1 背景

随着程序功能的日益复杂,程序的配置日益增多:各种功能的开关、参数的配置、服务器的地址……

对程序配置的期望值也越来越高:配置修改后实时生效,灰度发布,分环境、分集群管理配置,完善的权限、审核机制……

在这样的大环境下,传统的通过配置文件、数据库等方式已经越来越无法满足开发人员对配置管理的需求。

Apollo配置中心应运而生!

1.2 Apollo简介

Apollo(阿波罗)是携程框架部门研发的开源配置管理中心,能够集中化管理应用不同环境、不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限、流程治理等特性。

Apollo支持4个维度管理Key-Value格式的配置:

  1. application (应用)
  2. environment (环境)
  3. cluster (集群)
  4. namespace (命名空间)

同时,Apollo基于开源模式开发,开源地址:https://github.com/ctripcorp/apollo

2、Why Apollo

正是基于配置的特殊性,所以Apollo从设计之初就立志于成为一个有治理能力的配置发布平台,目前提供了以下的特性:

  • 统一管理不同环境、不同集群的配置

    • Apollo提供了一个统一界面集中式管理不同环境(environment)、不同集群(cluster)、不同命名空间(namespace)的配置。
    • 同一份代码部署在不同的集群,可以有不同的配置,比如zookeeper的地址等
    • 通过命名空间(namespace)可以很方便地支持多个不同应用共享同一份配置,同时还允许应用对共享的配置进行覆盖
  • 配置修改实时生效(热发布)

    • 用户在Apollo修改完配置并发布后,客户端能实时(1秒)接收到最新的配置,并通知到应用程序
  • 版本发布管理

    • 所有的配置发布都有版本概念,从而可以方便地支持配置的回滚
  • 灰度发布

    • 支持配置的灰度发布,比如点了发布后,只对部分应用实例生效,等观察一段时间没问题后再推给所有应用实例
  • 权限管理、发布审核、操作审计

    • 应用和配置的管理都有完善的权限管理机制,对配置的管理还分为了编辑和发布两个环节,从而减少人为的错误。
    • 所有的操作都有审计日志,可以方便地追踪问题
  • 客户端配置信息监控

    • 可以在界面上方便地看到配置在被哪些实例使用
  • 提供Java和.Net原生客户端

    • 提供了Java和.Net的原生客户端,方便应用集成
    • 支持Spring Placeholder, Annotation和Spring Boot的ConfigurationProperties,方便应用使用(需要Spring 3.1.1+)
    • 同时提供了Http接口,非Java和.Net应用也可以方便地使用
  • 提供开放平台API

    • Apollo自身提供了比较完善的统一配置管理界面,支持多环境、多数据中心配置管理、权限、流程治理等特性。不过Apollo出于通用性考虑,不会对配置的修改做过多限制,只要符合基本的格式就能保存,不会针对不同的配置值进行针对性的校验,如数据库用户名、密码,Redis服务地址等
    • 对于这类应用配置,Apollo支持应用方通过开放平台API在Apollo进行配置的修改和发布,并且具备完善的授权和权限控制
  • 部署简单

    • 配置中心作为基础服务,可用性要求非常高,这就要求Apollo对外部依赖尽可能地少
    • 目前唯一的外部依赖是MySQL,所以部署非常简单,只要安装好Java和MySQL就可以让Apollo跑起来
    • Apollo还提供了打包脚本,一键就可以生成所有需要的安装包,并且支持自定义运行时参数

3、Apollo at a glance

3.1 基础模型

如下即是Apollo的基础模型:

  1. 用户在配置中心对配置进行修改并发布
  2. 配置中心通知Apollo客户端有配置更新
  3. Apollo客户端从配置中心拉取最新的配置、更新本地配置并通知到应用

3.2 界面概览

上图是Apollo配置中心中一个项目的配置首页

  • 在页面左上方的环境列表模块展示了所有的环境和集群,用户可以随时切换。
  • 页面中央展示了两个namespace(application和FX.apollo)的配置信息,默认按照表格模式展示、编辑。用户也可以切换到文本模式,以文件形式查看、编辑。
  • 页面上可以方便地进行发布、回滚、灰度、授权、查看更改历史和发布历史等操作

3.3 添加/修改配置项

用户可以通过配置中心界面方便的添加/修改配置项,更多使用说明请参见应用接入指南

输入配置信息:

3.4 发布配置

通过配置中心发布配置:

填写发布信息:

3.5 客户端监听配置变化(Java API样例)

配置发布后,就能在客户端获取到了,以Java为例,获取配置的示例代码如下。Apollo客户端还支持和Spring整合,更多客户端使用说明请参见Java客户端使用指南和.Net客户端使用指南。

Config config = ConfigService.getAppConfig();
Integer defaultRequestTimeout = 200;
Integer requestTimeout = config.getIntProperty("requestTimeout", defaultRequestTimeout);

3.6 客户端监听配置变化

通过上述获取配置代码,应用就能实时获取到最新的配置了。

不过在某些场景下,应用还需要在配置变化时获得通知,比如数据库连接的切换等,所以Apollo还提供了监听配置变化的功能,Java示例如下:

Config config = ConfigService.getAppConfig();
config.addChangeListener(new ConfigChangeListener() {@Overridepublic void onChange(ConfigChangeEvent changeEvent) {for (String key : changeEvent.changedKeys()) {ConfigChange change = changeEvent.getChange(key);System.out.println(String.format("Found change - key: %s, oldValue: %s, newValue: %s, changeType: %s",change.getPropertyName(), change.getOldValue(),change.getNewValue(), change.getChangeType()));}}
});

3.7 Spring集成样例

Apollo和Spring也可以很方便地集成,只需要标注@EnableApolloConfig后就可以通过@Value获取配置信息:

@Configuration
@EnableApolloConfig
public class AppConfig {}

@Component
public class SomeBean {@Value("${request.timeout:200}")private int timeout;@ApolloConfigChangeListenerprivate void someChangeHandler(ConfigChangeEvent changeEvent) {if (changeEvent.isChanged("request.timeout")) {refreshTimeout();}}
}

Apollo学习(一)Apollo初学入门相关推荐

  1. Apollo学习笔记

    Apollo学习笔记 Apollo课程 智能驾驶入门课程 无人驾驶概览 1.软件层分为三层: 实时操作系统(RTOS):确保在给定时间内完成特定任务,实时时确保系统稳定性.驾驶安全性的重要要求.通过在 ...

  2. 万字讲解Apollo,全网Apollo资料整理和学习

    0 参考资料 0.1 Apollo各模块系列笔记记录 模块 参考文章 Cyber apollo介绍之cyber设计(五) - 知乎 (zhihu.com) apollo介绍之Cyber框架(十) - ...

  3. Apollo学习(超详细)

    Apollo 文章目录 Apollo 1. 学习地址 2. 概览 1. 什么是配置 2. 什么是配置中心 3. Apollo简介 1. 主流配置中心 1.1. 功能特性对比 1.2 总结 2. Apo ...

  4. ROS 初学入门学习及资源推荐

    ROS 初学入门学习及资源推荐 1 ROS简介 参考链接: https://baike.baidu.com/item/ros/4710560?fr=aladdin ROS 即 机器人操作系统(Robo ...

  5. Apollo星火计划学习笔记——第一讲 使用Apollo学习自动驾驶

    引言 如何学习自动驾驶? 自动驾驶是集车辆.计算机.电子电气.人工智能.通信等多学科应用为一体的的复杂系统.针对自身专业背景结合自动驾驶发展进行学习: 自动驾驶是通过智能系统来驾驶汽车从而取代了驾驶员 ...

  6. 学习笔记:星火第一讲-使用Apollo 学习自动驾驶

    星火第一讲-使用Apollo 学习自动驾驶 引言 如何学习自动驾驶? 自动驾驶是集车辆.计算机.电子电气.人工智能.通信等多学科应用为一体的的复杂系统.针对自身专业背景结合自动驾驶发展进行学习: 自动 ...

  7. 怎么学习CAD?初学CAD如何入门

    怎么学习CAD呢?想必小伙们在刚刚开始接触CAD时都会有这样的疑问,其实CAD很好学习的,只是很多小伙伴们可能看到图纸就望而却步,其实只要掌握好方法,学习CAD是很简单 的一件事! 第一:我们就需要了 ...

  8. apollo学习基础之三[适配器adapter学习]

    apollo学习基础之三[适配器adapter学习] 目录 apollo学习基础之三[适配器adapter学习] 1.适配封装设计 2. AdapterManager的设计 3.总结归纳: 我们知道, ...

  9. Apollo星火计划学习笔记——Apollo开放空间规划算法原理与实践

    文章目录 前言 1. 开放空间规划算法总体介绍 1.1 Task: OPEN_SPACE_ROI_DECIDER 1.2 Task: OPEN_SPACE_TRAJECTORY_PROVIDER 1. ...

最新文章

  1. Servlet生命周期与工作原理
  2. 2020 五大技术趋势:无人驾驶发展、机器视觉崛起、区块链实用化、人类增强技术、超自动化...
  3. Spark MLlib编程API入门系列之特征选择之R模型公式(RFormula)
  4. AngularJS相关网站存档
  5. C#发送Email邮件(实例:QQ邮箱和Gmail邮箱)
  6. win10设置默认输入法_为什么说win10越来越好用了?(技巧篇)
  7. uboot源码——C阶段的start_armboot函数
  8. seajs常用API整理
  9. python实现编译器链接器_Python入门之Python编译器
  10. 新iPhone将采用更大容量电池:最低3110mAh?
  11. 计算机软件销售收入会计,嵌入式软件产品销售额如何计算
  12. [论文必备]解决pdf复制到word出现换行排版混乱-自动整理小工具 ScholarAssist-免费文献段落格式整理软件
  13. 【观察】 全新紫光云:“云数智”底盘再升级,背后的三重新价值
  14. 计算机提示策略阻止安装,win7安装软件提示此程序被组策略阻止怎么办
  15. 基于 HTML5 + WebGL 的太阳系 3D 展示系统
  16. 请没有买房和买车的朋友一定认真的看一下(转)
  17. MySQL视图(view)基本用法
  18. N沟道和P沟道MOS管的四个不同点
  19. 计算机ABC分类法的步骤,ABC分类法的具体步骤
  20. 图像分辨率+像素+尺寸+文件内存大小

热门文章

  1. 全国计算机一级级考试试题及答案,全国计算机等级考试一级考试试题及答案
  2. java中的tomcatserverlet
  3. 蓝桥杯 二阶魔方旋转 模拟
  4. Tekton 与 Argo CD 结合实现 GitOps
  5. [转]计算机视觉入门
  6. android 监听图库变化,Android ContentObserver 监听图库变化
  7. Linux 批量修改密码
  8. RabbitMQ入门用法及消息模型案例
  9. 资源Resource的介绍
  10. 出现413 Request Entity Too Large问题的解决方法