编程开源技术交流,分享技术与知识

网站首页 > 开源技术 正文

disconf api nodejs应用(disconnection from)

wxchong 2024-07-21 07:09:21 开源技术 35 ℃ 0 评论

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

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表