当前位置:首页 » PHP技术

【分布式配置中心之disconf】

2018-06-11 08:21 本站整理 浏览(2)

Distributed Configuration Management Platform(分布式配置管理平台)

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

 

之前一直采用properties文件管理配置信息,若是集群则每个机器上都要拷贝一份,每次修改也需要依次修改。一直在寻找统一修改,实时生效,方便修改,分环境分系统的配置管理

 

Diamond则是淘宝开源的一种分布式配置管理服务的实现

disconf是来自百度的分布式配置管理平台,包括百度、滴滴出行、银联、网易、拉勾网、苏宁易购、顺丰科技 等知名互联网公司正在使用!

 

Xdiamond

1、基于数据库做配置存储

2、相对于diamond增加了权限设计,结合Secret key,保证配置的安全

3、配置缓存在本地,防止应用因为网络问题而不能启动

 

Qconf

1、奇虎 360 内部分布式配置管理工具

2、用C/C++编写,支持c/c++、shell、php、python 等语言

3、应用Zookeeper做集群管理

4、多进程的情况下,QPS 能够达到百万

 

etcd

1、使用Go语言编写,并通过Raft一致性算法处理日志复制以保证强一致性

 

主要目标:

1)部署极其简单:同一个上线包,无须改动配置,即可在 多个环境中(RD/QA/PRODUCTION) 上线

2)部署动态化:更改配置,无需重新打包或重启,即可 实时生效

3)统一管理:提供web平台,统一管理 多个环境(RD/QA/PRODUCTION)、多个产品 的所有配置

4)核心目标:一个jar包,到处运行


 模块信息

disconf-core: 分布式配置基础包模块

disconf-client: 分布式配置客户端模块, 依赖disconf-core包。 用户程序使用它作为Jar包进行分布式配置编程。

disconf-tool: 分布式配置工具包,依赖disconf-core包。 Disconf-tool是disconf的辅助工具类。

disconf-web: 分布式配置平台服务模块, 依赖disconf-core包。采用SpringMvc+纯HTML方式实现。 用户使用它来进行日常的分布式配置管理。

disconf-standalone-demo: 使用disconf的基于Spring的standalone demo程序

disconf-standalone-dubbo-demo: 集成了disconf和dubbo的基于Spring的standalone demo程序

disconf-spring-demo: 使用disconf的SpringMvc Web demo程序

功能特点

  • 支持配置(配置项+配置文件)的分布式化管理
  • 配置发布统一化
    • 配置发布、更新统一化:
      • 同一个上线包 无须改动配置 即可在 多个环境中(RD/QA/PRODUCTION) 上线
      • 配置存储在云端系统,用户统一管理 多个环境(RD/QA/PRODUCTION)、多个平台 的所有配置
    • 配置更新自动化:用户在平台更新配置,使用该配置的系统会自动发现该情况,并应用新配置。特殊地,如果用户为此配置定义了回调函数类,则此函数类会被自动调用。
  • 极简的使用方式(注解式编程 或 XML无代码侵入模式):我们追求的是极简的、用户编程体验良好的编程方式。目前支持两种开发模式:基于XML配置或者基于注解,即可完成复杂的配置分布式化。
  • 低侵入性或无侵入性、强兼容性:
    • 低侵入性:通过极少的注解式代码撰写,即可实现分布式配置。
    • 无侵入性:通过XML简单配置,即可实现分布式配置。
    • 强兼容性:为程序添加了分布式配置注解后,开启Disconf则使用分布式配置;若关闭Disconf则使用本地配置;若开启Disconf后disconf-web不能正常Work,则Disconf使用本地配置。
  • 支持配置项多个项目共享,支持批量处理项目配置。
  • 配置监控:平台提供自校验功能(进一步提高稳定性),可以定时校验应用系统的配置是否正确。

注:配置项是指某个类里的某个Field字段。

Disconf的功能特点描述图: