disconf api 应用

2016-05-30 11:10:05

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

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

包括 百度滴滴出行银联网易拉勾网苏宁易购顺丰科技 等知名互联网公司正在使用!

主要目标:

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

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

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

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


功能特点

  • 支持配置(配置项+配置文件)的分布式化管理

  • 配置发布统一化

    • 同一个上线包 无须改动配置 即可在 多个环境中(RD/QA/PRODUCTION) 上线

    • 配置存储在云端系统,用户统一管理 多个环境(RD/QA/PRODUCTION)、多个平台 的所有配置

    • 配置发布、更新统一化:

    • 配置更新自动化:用户在平台更新配置,使用该配置的系统会自动发现该情况,并应用新配置。特殊地,如果用户为此配置定义了回调函数类,则此函数类会被自动调用。

  • 极简的使用方式(注解式编程 或 XML无代码侵入模式):我们追求的是极简的、用户编程体验良好的编程方式。目前支持两种开发模式:基于XML配置或者基于注解,即可完成复杂的配置分布式化。

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

Disconf的功能特点描述图:


其它功能特点

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

    • 低侵入性:通过极少的注解式代码撰写,即可实现分布式配置。

    • 无侵入性:通过XML简单配置,即可实现分布式配置。

    • 强兼容性:为程序添加了分布式配置注解后,开启Disconf则使用分布式配置;若关闭Disconf则使用本地配置;若开启Disconf后disconf-web不能正常Work,则Disconf使用本地配置。

  • 支持配置项多个项目共享,支持批量处理项目配置。

  • 配置监控:平台提供自校验功能(进一步提高稳定性),可以定时校验应用系统的配置是否正确。

说了这么多 nodejs 如何应用呢

function reload_config(name, filename) {
    var deferred = Q.defer();

    var url = URL.format({
        hostname: disconf.host,
        port: disconf.port,
        pathname: disconf.path,
        protocol: "http",
        query: {
            app: disconf.app,
            env: disconf.env,
            version: disconf.version,
            key: name,// "core.properties",
            type: 0
        }
    });
    console.log(url) ;
    request.get(url, function (err, res, body) {
        if (err) {
            return deferred.reject(err);
        }
        console.log('config',body)
        deferred.resolve(body);
    });
    return deferred.promise;
}

特别的简单  request 一个get 请求即可获取到配置文件

config { type: 'dateFile',
  filename: 'logs/date',
  pattern: 'yyyy-MM-dd.log',
  alwaysIncludePattern: true }


这个呢 是利用开放api  直接发送http请求得到你想要的数据的


具体的文档 请查阅官方文档 https://github.com/knightliao/disconf/wiki/Tutorial12-web%E5%BC%80%E6%94%BEAPI-client


你打算打赏多少钱呢?

打赏
(微信扫一扫)