springbootconfig还没想好名字

配置中心设计思考

2017-08-02  本文已影响894人  FX_SKY

配置

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

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

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

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

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

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

什么是配置中心

配置中心用来集中管理应用不同环境(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长的关于配置中心的文章

上一篇下一篇

猜你喜欢

热点阅读