DistributedConfigurationManagementPlatform(分布式配置管理平台)。
专注于各种 分布式系统配置管理 的通用组件/通用平台,提供统一的配置管理服务。
包括 百度、滴滴打车、银联、网易、拉勾网 等知名互联网公司正在使用!
「disconf」在「2015年度新增开源软件排名TOP100(OSC开源中国提供)」中排名第16强。
主要目标:部署极其简单:同一个上线包,无须改动配置,即可在多个环境中(RD/QA/PRODUCTION)上线部署动态化:更改配置,无需重新打包或重启,即可实时生效统一管理:提供web平台,统一管理多个环境(RD/QA/PRODUCTION)、多个产品的所有配置支持微服务架构demoshttps://github.com/knightliao/disconf-demos-java
项目信息CLIENT端:Java:目前唯一支持语言python:打算支持PHP:暂未支持WEB管理端:JavaSpringMvc实现,前后端分离实现方式(基于Spring4.1.7.RELEASE)javaclientdisconf.gitbranchesandMavenversion:
dev(developbranch):2.6.31-SNAPSHOTmaster(stablebranch):2.6.31更新日志在MavenCentralRepository里查看 com.baidu.disconfJavaClientElegantUsagePreview注解式分布式配置使用方式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语言客户端。JAVAdisconf-core:分布式配置基础包模块disconf-client:分布式配置客户端模块,依赖disconf-core包。用户程序使用它作为Jar包进行分布式配置编程。disconf-tool:分布式配置工具包,依赖disconf-core包。Disconf-tool是disconf的辅助工具类,目前使用不多,建议不使用。管理端:disconf-web是统一的分布式配置管理平台。disconf-web:分布式配置平台服务模块,依赖disconf-core包。采用SpringMvc+纯HTML方式(前后端分离架构)实现。用户使用它来进行日常的分布式配置管理。用户指南clintjavaclient:disconf-client使用在您的MavenPOM文件里加入:
<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查询:
javaclientTutorials总体概述TutorialSummary功能总体概述文章介绍:分布式配置管理平台Disconf基于注解式的分布式配置(支持配置文件和配置项)推荐新建的项目使用disconf时使用
Tutorial1注解式分布式的配置文件Tutorial2注解式分布式的配置文件高级篇:配置更新的通知Tutorial3注解式分布式的配置项Tutorial4注解式分布式静态配置文件和静态配置项注:将配置文件移至一个专有类里,而不是分散在项目的各个地方,整个代码架构清晰易懂、易管理。即便如果哪天不使用disconf,也只需要将注解去掉即可。
基于XML的分布式配置(无代码侵入)(仅支持配置文件)推荐旧项目使用disconf时使用
Tutorial8基于XML的分布式配置文件管理,自动reloadTutorial5基于XML的分布式配置文件管理,不会自动reload,对于那些比较重的资源如jdbc等,特别有用demoshttps://github.com/knightliao/disconf-demos-java
其它Tutorial6disconf-web功能详解Tutorial7可自定义的部分托管的分布式配置Tutorialdisconf与dubbo的集成demoTutorial9实现真正意义上的统一上线包Tutorial10实现一个配置更新下载器agent配置说明异常考虑局限性和注意事项注意事项Zookeeper异常考虑详细设计和讨论disconf-client详细设计文档disconf-web详细设计文档细节讨论
评论