配置中心设计思考

作者: FX_SKY | 来源:发表于2017-08-02 16:21 被阅读894次

    配置

    配置(Configuration) 这个概念对于广大程序猿来说应该都不陌生,例如线程池大小、数据库连接、系统停服开关等等。

    最开始,我们的配置都是以key-value的形式存放在配置文件中的,比如 在Java开发中配置信息通常位于在项目resource目录下的properties文件中,

    <context:property-placeholder location="classpath:config.properties"/>
    

    在集中式开发时代,配置文件基本足够用了,因为那时配置的管理通常不会成为一个很大的问题,简单一点来说,系统上了生产之后,如果需要修改一个配置,登录到这台生产机器上,vi修改这个配置文件,然后reload一下并不是什么很大的负担。

    但是在互联网时代,我们的应用都是分布式系统,部署在N台机器上,让运维去线上一台一台的重启机器 肯定不靠谱。

    所以使用配置文件方式存在以下问题:

    • 需要手动修改配置文件;
    • 配置文件修改后需要重新编译打包;
    • 需要重启线上服务器配置才能生效 (项目集群时,更加令人崩溃) ;
    • 不同环境上线包不一致: 例如JDBC连接, 不同环境需要差异化配置;

    什么是配置中心

    配置中心用来集中管理应用不同环境(Dev、Test、Stage、Prod)、不同集群的配置,配置修改后能够实时推送到应用端。

    配置中心提供的核心功能(不仅限如此):

    • 提供配置管理中心, 支持在线管理配置信息;
    • 集中管理各环境的配置文件,支持版本管理(可以用来回滚);
    • 后台配置修改之后,客户端能快速的生效;
    • 配置集的导出\导入功能;
    • 需保证高性能、高可用;
    • 客户端支持各种语言;

    可选方案

    名称 介绍 特点
    淘宝(Diamond)[http://code.taobao.org/svn/diamond/trun] Diamond 配置实时生效,只支持java
    百度(Disconf)[https://github.com/knightliao/disconf] 分布式系统配置管理 配置实时生效,只支持java
    携程(Apollo)[https://github.com/ctripcorp/apollo] Apollo 配置实时生效,支持java、.Net
    360(QConf)[https://github.com/Qihoo360/QConf] QConf 是一个分布式配置管理工具 配置实时生效,支持c/c++、shell、php、python、lua、java、go、node 等语言
    (Spring Cloud Config)[http://cloud.spring.io/spring-cloud-config/] Spring 配置管理 基于git,配置修改后不生效

    目前已有开源解决方案,分别如下:

    名称 介绍 特点
    淘宝(Diamond)[http://code.taobao.org/svn/diamond/trun] Diamond 配置实时生效,只支持java
    百度(Disconf)[https://github.com/knightliao/disconf] 分布式系统配置管理 配置实时生效,只支持java
    携程(Apollo)[https://github.com/ctripcorp/apollo] Apollo 配置实时生效,支持java、.Net
    360(QConf)[https://github.com/Qihoo360/QConf] QConf 是一个分布式配置管理工具 配置实时生效,支持c/c++、shell、php、python、lua、java、go、node 等语言
    (Spring Cloud Config)[http://cloud.spring.io/spring-cloud-config/] Spring 配置管理 基于git,配置修改后不生效

    参考资料

    淘宝Diamond架构分析

    阿里中间件团队博客 一篇好TM长的关于配置中心的文章

    相关文章

      网友评论

      • 萧然AND沐橦:哥们,淘宝的开源解决方案Diamond,链接需要用户名和密码。svn是内网的链接么?

      本文标题:配置中心设计思考

      本文链接:https://www.haomeiwen.com/subject/lhqylxtx.html