分布式配置中心选型

随着业务的发展、微服务架构的升级,服务的数量、程序的配置日益增多(各类微服务、各类服务器地址、各类参数),传统的配置文件方式和数据库的方式已没法知足开发人员对配置管理的要求:git

  • 安全性:配置跟随源代码保存在代码库中,容易形成配置泄漏。
  • 时效性:修改配置,须要重启服务才能生效。
  • 局限性:没法支持动态调整:例如日志开关、功能开关。

所以,分布式配置中心应运而生!github

开源项目

关于分布式配置中心,网上已经有不少开源的解决方案,例如:shell

Apollo

Apollo(阿波罗)是携程框架部门研发的分布式配置中心,可以集中化管理应用不一样环境、不一样集群的配置,配置修改后可以实时推送到应用端,而且具有规范的权限、流程治理等特性,适用于微服务配置管理场景。 项目地址:github.com/ctripcorp/a…数据库

Diamond

Diamond是淘宝研发的分布式配置管理系统。使用Diamond可让集群中的服务进程动态感知数据的变化,无需重启服务就能够实现配置数据的更新。安全

项目地址:github.com/gzllol/diam…服务器

Disconf

专一于各类「分布式系统配置管理」的「通用组件」和「通用平台」, 提供统一的「配置管理服务」 架构

项目地址:github.com/knightliao/…并发

项目对比

综合对比,以为携程的Apollo 功能强大完善,github上开源社区比较活跃,代码一直在维护,并且文档写得清楚,故最终选择Apollo 做为咱们的分布式配置中心。下面简要介绍下Apollo项目。框架

Apollo简介

Apollo(阿波罗)是携程框架部门研发的分布式配置中心,可以集中化管理应用不一样环境、不一样集群的配置,配置修改后可以实时推送到应用端,而且具有规范的权限、流程治理等特性,适用于微服务配置管理场景。 服务端基于Spring Boot和Spring Cloud开发,打包后能够直接运行,不须要额外安装Tomcat等应用容器。 Java客户端不依赖任何框架,可以运行于全部Java运行时环境,同时对Spring/Spring Boot环境也有较好的支持。 .Net客户端不依赖任何框架,可以运行于全部.Net运行时环境。分布式

特性

  • 统一管理不一样环境、不一样集群的配置
    • 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还提供了打包脚本,一键就能够生成全部须要的安装包,而且支持自定义运行时参数

发布配置

经过配置中心发布配置: 填写发布信息:

客户端获取配置(Java API样例)

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

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

客户端监听配置变化

经过上述获取配置代码,应用就能实时获取到最新的配置了。 不过在某些场景下,应用还须要在配置变化时得到通知,好比数据库链接的切换等,因此Apollo还提供了监听配置变化的功能,Java示例以下:

Config config = ConfigService.getAppConfig();
config.addChangeListener(new ConfigChangeListener() {
  @Override
  public 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()));
     }
  }
});
复制代码

Spring集成样例

Apollo和Spring也能够很方便地集成,只须要标注@EnableApolloConfig后就能够经过@Value获取配置信息:

@Configuration
@EnableApolloConfig
public class AppConfig {}

@Component
public class SomeBean {
    //timeout的值会自动更新
    @Value("${request.timeout:200}")
    private int timeout;
}
复制代码

总结

本文主要介绍和对比了几种开源分布式配置中心的选型,并重点介绍了下咱们最终选择的携程Apollo(阿波罗)分布式配置中心的特性和简单使用,有兴趣的读者能够到具体项目的官网进行详细研究。

相关文章
相关标签/搜索