• 分布式配置管理平台-Disconf


    项目地址:https://github.com/knightliao/disconf

    官方文档:http://disconf.readthedocs.io/zh_CN/latest/(建议先看官方文档)

    主要目标

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

    demos

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

    项目信息

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

    重要功能特点

    • 支持配置(配置项+配置文件)的分布式化管理
    • 配置发布统一化
      • 配置发布、更新统一化:
        • 同一个上线包 无须改动配置 即可在 多个环境中(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-web是统一的分布式配置管理平台。disconf-web: 分布式配置平台服务模块, 依赖disconf-core包。采用SpringMvc+纯HTML方式(前后端分离架构)实现。用户使用它来进行日常的分布式配置管理。

    用户指南

    java client: disconf-client 使用

    在您的 Maven POM 文件里加入:

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

    server: disconf-web 使用

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

    全新主页,高清大图:

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

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

     参考资料

    https://oschina.net/p/disconf

    http://www.cnblogs.com/majinju/p/4502246.html

  • 相关阅读:
    lua学习项目笔记
    Jenkins 安装、配置与项目新建及构建
    Gitlab的安装及项目新建
    PHP常见排序算法
    抽象类和接口的区别
    分布式版本控制系统Git的安装及使用
    深入解析OpenCart的代理类proxy
    PHP模式设计之单例模式、工厂模式、注册树模式、适配器模式、观察者模式
    linux命令行传递参数定期执行PHP文件
    php类中的$this,static,const,self这几个关键字使用方法
  • 原文地址:https://www.cnblogs.com/junzi2099/p/8257320.html
Copyright © 2020-2023  润新知