配置发布、服务注册发现框架:Nacos

概述

Nacos是一个更易于构建云原生应用的动态服务发现、配置管理和服务的管理平台。

Nacos帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。

Nacos的关键特性包括:

  • 服务发现和服务健康监测

  • 动态配置服务

  • 动态配置服务

安装

源码安装


git clone https://github.com/alibaba/nacos.git

cd nacos/

mvn -Prelease-nacos clean install -U 

ls -al distribution/target/

// change the $version to your actual path

cd distribution/target/nacos-server-$version/nacos/bin

压缩包安装


unzip nacos-server-$version.zip 或者 tar -xvf nacos-server-$version.tar.gz

cd nacos/bin

启动与关闭

  • Linux/Unix/Mac:启动命令(standalone代表着单机模式运行,非集群模式):

sh startup.sh -m standalone

sh shutdown.sh

  • Windows

cmd startup.cmd

cmd shutdown.cmd

服务注册,发现与配置管理

  1. 服务注册:

curl -X PUT 'http://127.0.0.1:8848/nacos/v1/ns/instance?serviceName=nacos.naming.serviceName&ip=20.18.7.10&port=8080'

  1. 服务发现:curl -X GET 'http://127.0.0.1:8848/nacos/v1/ns/instances?serviceName=nacos.naming.serviceName'

  2. 发布配置:curl -X POST "http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=nacos.cfg.dataId&group=test&content=HelloWorld"

  3. 获取配置:curl -X GET "http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=nacos.cfg.dataId&group=test"

nacos的编程使用

配置的读取与发布

编写应用程序配置文件的管理是一项繁杂的任务,如qa,dev,prod3个环境的数据库配置各有不同,上线时一不留神,极易容易搞错,那势必造成上线失败,另一方面,但配置修改时,你还得重启服务,借助nacos这一切将变得更加简单,以下代码用来发布配置和读取配置,代码如下:


@RequestMapping(value = "/config/get",method=RequestMethod.GET)

@ResponseBody

public String get(@RequestParam("dataId") String dataId,@RequestParam(name="group",defaultValue="DEFAULT_GROUP") String group) {

try {

Properties properties = new Properties();

properties.put("serverAddr", nacos);

ConfigService configService = NacosFactory.createConfigService(properties);

String content = configService.getConfig(dataId, group, 5000);

return content;

} catch (NacosException e) {

e.printStackTrace();

}

return "";

}

@RequestMapping(value = "/config/save",method=RequestMethod.GET)

@ResponseBody

public boolean save(@RequestParam("dataId") String dataId,@RequestParam(name="group",defaultValue="DEFAULT_GROUP") String group,@RequestParam("content") String content) {

try {

Properties properties = new Properties();

properties.put("serverAddr", nacos);

ConfigService configService = NacosFactory.createConfigService(properties);

boolean res = configService.publishConfig(dataId, group, content);

configService.addListener(dataId, group, new Listener() {

@Override

public void receiveConfigInfo(String configInfo) {

System.out.println("receiveConfigInfo:"+configInfo);

}

@Override

public Executor getExecutor() {

return null;

}

});

return res;

} catch (NacosException e) {

e.printStackTrace();

}

return false;

}

在listener里,但配置项发生变更时,会实时通知到您的应用。

服务的注册、发现

在我们开发系统中,经常会碰到服务的冗余部署,以便在某些服务器出现故障时,不影响最终服务的运行。比如聊天系统里的消息投递服务,各种微服务等,nacos通过API帮助您快速定位一个健康的服务以供您使用,通过如下代码:

Instance selectOneHealthyInstance(String serviceName) throws NacosException;

你可以注册一个服务到nacos里,nacos自动帮您检测服务的健康状态,注册服务代码如下:


NamingService namingService = NamingFactory.createNamingService("IP:8848");

//日志中心服务注册,非集群模式

Instance instance = new Instance();

instance.setIp("192.168.1.154");

instance.setPort(23105);

instance.setHealthy(true);

instance.setWeight(2.0);

Map<String, String> instanceMeta = new HashMap<>();

instanceMeta.put("site", "et2");

instance.setMetadata(instanceMeta);

namingService.registerInstance(serviceName, instance);

在控制台你可以看到当前服务的健康状态(准实时检测):

image

通过nacos的客户端API,你就可以编写高可靠性的后台服务了。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容