当前位置: 首页 > news >正文

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

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

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

主要目标:

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

项目信息

  • 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.28-SNAPSHOT
  • master(stable branch):2.6.27
  • 更新日志
  • 在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使用本地配置。
  • 支持配置项多个项目共享,支持批量处理项目配置。
  • 配置监控:平台提供自校验功能(进一步提高稳定性),可以定时校验应用系统的配置是否正确。

模块架构图

查看大图

模块信息

  • 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方式(前后端分离架构)实现。用户使用它来进行日常的分布式配置管理。
  • demo
    • JAVA client DEMO:
      • disconf-standalone-demo: 使用disconf的基于Spring的standalone demo程序
      • disconf-standalone-dubbo-demo: 集成了disconf和dubbo的基于Spring的standalone demo程序
      • disconf-spring-boot-demo: 使用disconf的spring-boot demo程序,更少的配置

用户指南

clint

java client: disconf-client 使用

在您的 Maven POM 文件里加入:

<dependency>
    <groupId>com.baidu.disconf</groupId>
    <artifactId>disconf-client</artifactId>
    <version>2.6.27</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等,特别有用

其它

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

详细设计和讨论

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

大家都在使用disconf

  • [百度](5+条产品线使用)
  • 润生活 (千万融资,全线产品使用)
  • 拉勾网
  • 人脉通 (目前已B轮融资,4条产品线使用)
  • 普联(Tp-link)技术有限公司
  • 杭州数梦工场科技有限公司
  • 众钱网
  • 更多

转载于:https://my.oschina.net/zhanghaiyang/blog/593682

相关文章:

  • centos系统的时间时区和MySQL的时间时区问题
  • java架构师之路:推荐的15本书
  • 学习python cgi的一点心得体会
  • Linux用户管理 (3)
  • linux下cat命令详解
  • “达观杯”文本分类挑战赛新手入门代码
  • Maven类包冲突终极解决方案
  • CDIF: 基于REST和JSON的SOA软件框架
  • 步步为营 .NET 设计模式学习笔记 二十四、Factory Method(工厂方法模式)
  • 杉杉股份聘方正科技前副总任伟泉掌帅印
  • npm安装任何包报错,解决方法:
  • Windows 7快速定位照片方法
  • Calendar类,运用Calendar类打印日历
  • 禁止浏览器自动保存密码弹框
  • tomcat:javax.servlet.http.HttpServletRequest cannot be resolved
  • 【翻译】babel对TC39装饰器草案的实现
  • 2017前端实习生面试总结
  • CentOS学习笔记 - 12. Nginx搭建Centos7.5远程repo
  • IP路由与转发
  • JavaScript设计模式之工厂模式
  • leetcode讲解--894. All Possible Full Binary Trees
  • Mysql数据库的条件查询语句
  • Travix是如何部署应用程序到Kubernetes上的
  • unity如何实现一个固定宽度的orthagraphic相机
  • 初识MongoDB分片
  • 从零搭建Koa2 Server
  • 基于Android乐音识别(2)
  • 日剧·日综资源集合(建议收藏)
  • 如何使用Mybatis第三方插件--PageHelper实现分页操作
  • 扫描识别控件Dynamic Web TWAIN v12.2发布,改进SSL证书
  • 为物联网而生:高性能时间序列数据库HiTSDB商业化首发!
  • 原生 js 实现移动端 Touch 滑动反弹
  • Python 之网络式编程
  • ​创新驱动,边缘计算领袖:亚马逊云科技海外服务器服务再进化
  • # 深度解析 Socket 与 WebSocket:原理、区别与应用
  • #pragma once与条件编译
  • (2.2w字)前端单元测试之Jest详解篇
  • (读书笔记)Javascript高级程序设计---ECMAScript基础
  • (附源码)spring boot公选课在线选课系统 毕业设计 142011
  • (顺序)容器的好伴侣 --- 容器适配器
  • (四)汇编语言——简单程序
  • (一)WLAN定义和基本架构转
  • (原創) 如何解决make kernel时『clock skew detected』的warning? (OS) (Linux)
  • (转)IIS6 ASP 0251超过响应缓冲区限制错误的解决方法
  • .htaccess 强制https 单独排除某个目录
  • .NET Standard、.NET Framework 、.NET Core三者的关系与区别?
  • .NET设计模式(7):创建型模式专题总结(Creational Pattern)
  • @Async注解的坑,小心
  • @modelattribute注解用postman测试怎么传参_接口测试之问题挖掘
  • [ C++ ] STL_stack(栈)queue(队列)使用及其重要接口模拟实现
  • []串口通信 零星笔记
  • [20150904]exp slow.txt
  • [20160807][系统设计的三次迭代]
  • [C++]Leetcode17电话号码的字母组合
  • [Docker]十一.Docker Swarm集群raft算法,Docker Swarm Web管理工具