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
本文暂时没有评论,来添加一个吧(●'◡'●)