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

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

包括 百度滴滴打车银联网易拉勾网 等知名互联网公司正在使用!

「disconf」在「2015 年度新增开源软件排名 TOP 100(OSC开源中国提供)」中排名第16强。

主要目标:

  • 部署极其简单:同一个上线包,无须改动配置,即可在 多个环境中(RD/QA/PRODUCTION) 上线
  • 部署动态化:更改配置,无需重新打包或重启,即可 实时生效
  • 统一管理:提供web平台,统一管理 多个环境(RD/QA/PRODUCTION)、多个产品 的所有配置
  • 支持微服务架构

demos

https://github.com/knightliao/disconf-demos-java

项目信息

  • CLIENT 端:

    • Java: 目前唯一支持语言
    • python:打算支持
    • PHP:暂未支持
  • WEB 管理端:
    • Java SpringMvc 实现,前后端分离 实现方式(基于Spring 4.1.7.RELEASE)

java client

disconf.git branches and Maven version:

  • dev(develop branch): 2.6.31-SNAPSHOT
  • master(stable branch):2.6.31
  • 更新日志
  • 在Maven Central Repository里查看 com.baidu.disconf

Java Client Elegant Usage Preview

  • 注解式分布式配置使用方式
  • XML配置式分布式配置方式

当前版本功能特点

  • 支持配置(配置项+配置文件)的分布式化管理
  • 配置发布统一化
  • 极简的使用方式(注解式编程 或 XML无代码侵入模式)
  • 低侵入性或无侵入性、强兼容性

未来版本(完全版)功能特点

Disconf的功能特点描述图:

查看大图

重要功能特点

  • 支持配置(配置项+配置文件)的分布式化管理
  • 配置发布统一化
    • 配置发布、更新统一化:

      • 同一个上线包 无须改动配置 即可在 多个环境中(RD/QA/PRODUCTION) 上线
      • 配置存储在云端系统,用户统一管理 多个环境(RD/QA/PRODUCTION)、多个平台 的所有配置
    • 配置更新自动化:用户在平台更新配置,使用该配置的系统会自动发现该情况,并应用新配置。特殊地,如果用户为此配置定义了回调函数类,则此函数类会被自动调用。
  • 配置异构系统管理
    • 异构包部署统一化:这里的异构系统是指一个系统部署多个实例时,由于配置不同,从而需要多个部署包(jar或war)的情况(下同)。使用Disconf后,异构系统的部署只需要一个部署包,不同实例的配置会自动分配。特别地,在业界大量使用部署虚拟化(如JPAAS系统,SAE,BAE)的情况下,同一个系统使用同一个部署包的情景会越来越多,Disconf可以很自然地与他天然契合。
    • 异构主备自动切换:如果一个异构系统存在主备机,主机发生挂机时,备机可以自动获取主机配置从而变成主机。
    • 异构主备机Context共享工具:异构系统下,主备机切换时可能需要共享Context。可以使用Context共享工具来共享主备的Context。
  • 极简的使用方式(注解式编程 或 XML无代码侵入模式):我们追求的是极简的、用户编程体验良好的编程方式。目前支持两种开发模式:基于XML配置或者基于注解,即可完成复杂的配置分布式化。

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

其它功能特点

  • 低侵入性或无侵入性、强兼容性:

    • 低侵入性:通过极少的注解式代码撰写,即可实现分布式配置。
    • 无侵入性:通过XML简单配置,即可实现分布式配置。
    • 强兼容性:为程序添加了分布式配置注解后,开启Disconf则使用分布式配置;若关闭Disconf则使用本地配置;若开启Disconf后disconf-web不能正常Work,则Disconf使用本地配置。
  • 支持配置项多个项目共享,支持批量处理项目配置。
  • 配置监控:平台提供自校验功能(进一步提高稳定性),可以定时校验应用系统的配置是否正确。

模块架构图

查看大图

模块信息

  • CLIENT: client目标是支持多语言。目前只提供了java语言客户端。

    • JAVA

      • disconf-core: 分布式配置基础包模块
      • disconf-client: 分布式配置客户端模块, 依赖disconf-core包。 用户程序使用它作为Jar包进行分布式配置编程。
      • disconf-tool: 分布式配置工具包,依赖disconf-core包。 Disconf-tool是disconf的辅助工具类, 目前使用不多,建议不使用。
  • 管理端:disconf-web是统一的分布式配置管理平台。disconf-web: 分布式配置平台服务模块, 依赖disconf-core包。采用SpringMvc+纯HTML方式(前后端分离架构)实现。用户使用它来进行日常的分布式配置管理。

用户指南

clint

java client: disconf-client 使用

在您的 Maven POM 文件里加入:

<dependency><groupId>com.baidu.disconf</groupId><artifactId>disconf-client</artifactId><version>2.6.31</version>
</dependency>

server: disconf-web 使用

部署方法请参见:https://github.com/knightliao/disconf/tree/master/disconf-web

全新主页,高清大图:

APP+环境+版本+ZK查询:

http://ww1.sinaimg.cn/mw1024/60c9620fgw1emyww39wjmj20qw0keq6m.jpg

java client Tutorials

总体概述

  • TutorialSummary 功能总体概述
  • 文章介绍:分布式配置管理平台Disconf

基于注解式的分布式配置(支持配置文件和配置项)

推荐新建的项目使用disconf时使用

  • Tutorial 1 注解式分布式的配置文件
  • Tutorial 2 注解式分布式的配置文件高级篇: 配置更新的通知
  • Tutorial 3 注解式分布式的配置项
  • Tutorial 4 注解式分布式静态配置文件和静态配置项

注:将配置文件移至一个专有类里,而不是分散在项目的各个地方,整个代码架构清晰易懂、易管理。 即便如果哪天不使用disconf,也只需要将注解去掉即可。

基于XML的分布式配置(无代码侵入)(仅支持配置文件)

推荐旧项目使用disconf时使用

  • Tutorial 8 基于XML的分布式配置文件管理,自动reload
  • Tutorial 5 基于XML的分布式配置文件管理,不会自动reload,对于那些比较重的资源如jdbc等,特别有用

demos

https://github.com/knightliao/disconf-demos-java

其它

  • Tutorial 6 disconf-web 功能详解
  • Tutorial 7 可自定义的部分托管的分布式配置
  • Tutorial disconf与dubbo的集成 demo
  • Tutorial 9 实现真正意义上的统一上线包
  • Tutorial 10 实现一个配置更新下载器agent
  • 配置说明
  • 异常考虑
  • 局限性和注意事项
  • 注意事项
  • Zookeeper异常考虑

详细设计和讨论

  • disconf-client详细设计文档
  • disconf-web详细设计文档
  • 细节讨论

大家都在使用disconf

  • [百度](20+条产品线使用)
  • 滴滴打车
  • [银联]
  • 网易
  • 润生活 (千万融资,全线产品使用)
  • 拉勾网
  • 人脉通 (目前已B轮融资,4条产品线使用)
  • 普联(Tp-link)技术有限公司
  • 杭州数梦工场科技有限公司
  • 众钱网
  • 快速递
  • 杭州同盾科技
  • 杭州趣维科技 (数千万RMB A轮投资)
  • 百世物流科技 (在全国建立了400多个运作中心和250万平米的仓库及转运中心,拥有30000多员工和上万个认证加盟商及合作伙伴)
  • 仙人掌股票(2015年度最火app,所有产品线已全面接入disconf)
  • 更多

他人评价

快速递技术总监:

http://ww1.sinaimg.cn/bmiddle/60c9620fjw1ergy58j978j20i302u0t2.jpg

润生活总监:

http://ww4.sinaimg.cn/bmiddle/60c9620fjw1est6ptf2dlj20ab01udfy.jpg

人脉通后端RD:

http://ww4.sinaimg.cn/bmiddle/60c9620fjw1est6pzqo68j208k05tjrm.jpg

开源中国社区:

「disconf」在「2015 年度新增开源软件排名 TOP 100(OSC开源中国提供)」中排名第16强。

群·联系·讨论

  • disconf技术QQ群: 239203866
  • 媒体报道与网友教程

关于我

  • pfrock: A plugin-based server for running fake HTTP and socket services (especially SOA service) using Python.
  • 搜索引擎推荐:sov5搜索引擎, 支持谷歌网页搜索和电影搜索
  • python论坛推荐:Django中国社区
  • 我的微信:knightliao
  • 我的简历
  • 联系与赞助作者 捐助者会留名

knightliao / disconf

Watch211 Star942 Fork505

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

Issues
#93 在哪可以自定义disconf.properties路径? by gradysong  2016-04-30
#91 disconf-client是否可以支持Config类的继承? by caokaifang  2016-04-28
#89 java.lang.IllegalArgumentException: wrong number of arguments by bwzhang2011  2016-04-27
#88 可有计划增加对其他类型如json/yaml格式文件的支持 by GTaurus  2016-04-28
#87 急求disconf配置平台支持批量配置项 by m5jun  2016-04-22

master分支代码最近更新:2016-04-30

下载zip

Disconf最新更新资讯,共1条  (投递新闻)

  • Disconf —— 来自百度的分布式配置管理平台1年前0评/32阅
  • 授权协议: apache2.0
  • 开发语言: Java
  • 操作系统:跨平台
  • 收录时间: knightliao -> 2015年04月13日  (国产软件 or 国人参与)

分布式配置管理平台 Disconf相关推荐

  1. 百度分布式配置管理平台-Disconf

    转载自 [推荐]百度分布式配置管理平台-Disconf Disconf介绍 全称:Distributed Configuration Management Platform,即分布式配置管理平台. D ...

  2. jenkins详解和分布式配置管理平台 Disconf

    1. jenkins详解:https://blog.csdn.net/qq_26848099/article/details/78901240 一.相关概念 1.1 Jenkins概念: Jenkin ...

  3. 分布式配置管理平台Disconf

    disconf是一套完整的基于zookeeper的分布式配置统一解决方案 功能特点: 支持配置的分布式化管理,配置发布统一化 极简的使用方式(注解式编程 或 XML代码无代码侵入模式) 需要Sprin ...

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

    2019独角兽企业重金招聘Python工程师标准>>> 专注于各种 分布式系统配置管理 的通用组件/通用平台, 提供统一的配置管理服务. 主要目标: 部署极其简单:同一个上线包,无须 ...

  5. Java Web学习总结(23)——Distributed Configuration Management Platform(分布式配置管理平台)

    专注于各种 分布式系统配置管理 的通用组件/通用平台, 提供统一的配置管理服务. 主要目标: 部署极其简单:同一个上线包,无须改动配置,即可在 多个环境中(RD/QA/PRODUCTION) 上线 部 ...

  6. Java Web学习总结(23)——Distributed Configuration Management Platform(分布式配置管理平台)...

    专注于各种 分布式系统配置管理 的通用组件/通用平台, 提供统一的配置管理服务. 主要目标: 部署极其简单:同一个上线包,无须改动配置,即可在 多个环境中(RD/QA/PRODUCTION) 上线 部 ...

  7. XXL-CONF v1.4.1 发布,分布式配置管理平台

    版本新特性: 1.Ehcache缓存对象CacheNode序列化优化: 2.XML配置方式,Bean初始化时配置加载逻辑优化: 3.升级多项依赖至较新版本:spring.spring-boot.jac ...

  8. 《分布式配置管理平台XXL-CONF》

    分布式配置管理平台XXL-CONF 一.简介 1.1 概述 XXL-CONF 是一个分布式配置管理平台,拥有"强一致性.毫秒级动态推送.多环境.多语言.配置监听.权限控制.版本回滚" ...

  9. 分布式配置管理平台Disconf--转

    原文地址:http://www.liaoqiqi.com/post/219 摘要 为了更好的解决分布式环境下多台服务实例的配置统一管理问题,本文提出了一套完整的分布式配置管理解决方案(简称为disco ...

最新文章

  1. ASML 1nm光刻机研究进展:摩尔定律尚未结束
  2. [Leetcode]-containsNearbyDuplicate
  3. 利用触摸屏获取事件坐标
  4. log4j日志文件 log4j.xml log4j.properties配置
  5. matlab 中一些对数组或矩阵的处理
  6. PostgreSQL 性能优化方法 - 1
  7. 兄dei,来封装一个自定义事件玩玩
  8. 各种流行的编程风格 你属于哪一种?
  9. mil和mm之间的换算
  10. 10个技巧,帮你改进UI设计
  11. SQL SERVER2000企业版安装过程-如何选择授权模式?
  12. 基于XTerm模拟发包实现
  13. 关于ruby on rails启动服务器 Webpacker configuration file not found问题
  14. 关于Win10已设置默认打开方式的清除方法
  15. 计算机毕业设计Java城市出行行程智能推荐系统(源码+系统+mysql数据库+lw文档)
  16. pip失败——sys.stderr.write(f“ERROR: {exc}“) SyntaxError: invalid syntax
  17. andorid 手机APP应用程序开发介绍
  18. python语句的续行符是_python续行符是什么
  19. HTML5本地视频播放器设计(+弹幕功能)
  20. PyQt5_pyqtgraph股票RSI指标

热门文章

  1. 返璞归真-删除文件默认打开方式
  2. 使用MIC进行变量选择
  3. HCIA——TCP及其三次握手,问题
  4. 仿新浪热门微博页面动态添加Tab标签与Fragment联动的实现
  5. Tableau疫情可视化
  6. 斐波那契序列递归方法_斐波那契和卢卡斯序列
  7. (C++)1~10000质数表
  8. 【软件技术基础】02
  9. 【渝粤教育】电大中专Office办公软件 (15)作业 题库
  10. Ubuntu 18.04 LTS版本 谷歌拼音输入法安装