Nacos是一个服务发现、配置管理和服务管理的组件。
说到服务注册与发现,我想到Eureka、Zookeeper
说到服务治理,我想到Dubbo
说到配置管理,我想到Apollo
作为后起之秀的Nacos更强大更简洁
Nacos的文档很详细,都是中文,不再详述,此处只摘抄几点比较重要的内容,算是对自己看了一下午的一个总结
1. 什么是Nacos
Nacos 可以快速实现动态服务发现、服务配置、服务元数据及流量管理。
Nacos 支持几乎所有主流类型的“服务”的发现、配置和管理。
特性:
- 服务发现和服务健康监测
Nacos 支持基于 DNS 和 基于 RPC 的服务发现。服务提供者使用 原生SDK、OpenAPI、或一个独立的Agent TODO注册 Service 后,服务消费者可以使用DNS TODO 或HTTP&API查找和发现服务。
Nacos 提供对服务的实时的健康检查,阻止向不健康的主机或服务实例发送请求。Nacos 支持传输层 (PING 或 TCP)和应用层 (如 HTTP、MySQL、用户自定义)的健康检查。 对于复杂的云环境和网络拓扑环境中(如 VPC、边缘网络等)服务的健康检查,Nacos 提供了 agent 上报模式和服务端主动检测2种健康检查模式。Nacos 还提供了统一的健康检查仪表盘,帮助您根据健康状态管理服务的可用性及流量。
- 动态配置服务
更新配置后无需重新部署或重启服务,立即生效;
Nacos 提供了一个简洁易用的UI(控制台)帮助您管理所有的服务和应用的配置;
Nacos 提供包括配置版本跟踪、金丝雀发布、一键回滚配置以及客户端配置更新状态跟踪等功能;
- 动态 DNS 服务
动态 DNS 服务支持权重路由,你可以更容易地实现中间层负载均衡、更灵活的路由策略、流量控制以及数据中心内网的简单DNS解析服务。
- 服务及其元数据管理
Nacos 能让你从微服务平台建设的视角管理数据中心的所有服务及元数据,包括管理服务的描述、生命周期、服务的静态依赖分析、服务的健康状态、服务的流量管理、路由及安全策略、服务的 SLA 以及最首要的 metrics 统计数据。
2. 为什么用Nacos
用不用主要取决于:
- 是否能够更好为业务发展做支撑;
- 功能是否满足需求;
- 是否稳定,是否经过大规模的生成环境验证;
- 是否有完善的文档和活跃的社区;
阿里开源的组件还是比较受欢迎的,先来看Nacos地图
2.1. 架构图
这张图很眼熟,如果去掉蓝色的块儿,就跟Dubbo的那个结构图很像了(提供方、消费方、注册中心、监控、控制台)
逻辑架构及其组件介绍
2.2. 数据模型
Nacos 数据模型 Key 由三元组唯一确定, Namespace默认是空串,公共命名空间(public),分组默认是 DEFAULT_GROUP。
3. 怎么用Nacos
从 最新稳定版本 下载 nacos-server-$version.zip 包
wget https://github.com/alibaba/nacos/releases/download/1.1.4/nacos-server-1.1.4.tar.gz
tar -zxf nacos-server-1.1.4.tar.gz
cd nacos/bin
sh startup.sh -m standalone
sh shutdown.sh
服务端(Nacos Server)启动以后,可以先一下控制台
http://127.0.0.1:8848/nacos
初始用户名密码是:nacos/nacos
接下来,编写客户端(Nacos Client)程序
这里用Spring Boot写一个测试用例
pom.xml
1
2 xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
3 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
4 4.0.0
5
6 org.springframework.boot
7 spring-boot-starter-parent
8 2.2.2.RELEASE
9
10
11 com.cjs.example
12 nacos-spring-boot-config-example
13 0.0.1-SNAPSHOT
14 nacos-spring-boot-config-example
15
16
17 1.8
18
19
20
21
22 org.springframework.boot
23 spring-boot-starter-web
24
25
26
27 com.alibaba.boot
28 nacos-config-spring-boot-starter
29 0.2.1
30
31
32
33
34
35
36 org.springframework.boot
37 spring-boot-maven-plugin
38
39
40
41
42
刚才已经启动了服务端,默认端口是8848,因此我们需要告诉客户端服务端的地址
application.properties
nacos.config.server-addr=127.0.0.1:8848
使用 @NacosPropertySource 加载 dataId 为 example 的配置源,并开启自动更新
1 package com.cjs.example.nacos;
2
3 import com.alibaba.nacos.spring.context.annotation.config.NacosPropertySource;
4 import org.springframework.boot.SpringApplication;
5 import org.springframework.boot.autoconfigure.SpringBootApplication;
6
7 @SpringBootApplication
8 @NacosPropertySource(dataId = "example", autoRefreshed = true)
9 public class NacosSpringBootConfigExampleApplication {
10
11 public static void main(String[] args) {
12 SpringApplication.run(NacosSpringBootConfigExampleApplication.class, args);
13 }
14
15 }
通过 Nacos 的 @NacosValue 注解设置属性值
1 package com.cjs.example.nacos.controller;
2
3 import com.alibaba.nacos.api.config.annotation.NacosValue;
4 import org.springframework.web.bind.annotation.GetMapping;
5 import org.springframework.web.bind.annotation.RequestMapping;
6 import org.springframework.web.bind.annotation.RestController;
7
8 @RestController
9 @RequestMapping("/config")
10 public class ConfigController {
11
12 @NacosValue(value = "${useLocalCache:false}", autoRefreshed = true)
13 private boolean useLocalCache;
14
15 @GetMapping("/get")
16 private boolean get() {
17 return useLocalCache;
18 }
19 }
启动 NacosConfigApplication,调用 curl http://localhost:8080/config/get,返回内容是 false
通过调用 Nacos Open API 向 Nacos server 发布配置:dataId 为example,内容为useLocalCache=true
curl-X POST "http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=example&group=DEFAULT_GROUP&content=useLocalCache=true"
再次访问 http://localhost:8080/config/get,此时返回内容为true,说明程序中的useLocalCache值已经被动态更新了
注册一个服务再看
curl-X POST 'http://127.0.0.1:8848/nacos/v1/ns/instance?serviceName=example&ip=127.0.0.1&port=8080'
3.1. 服务注册、发现和配置管理
服务注册
curl-X POST 'http://127.0.0.1:8848/nacos/v1/ns/instance?serviceName=nacos.naming.serviceName&ip=20.18.7.10&port=8080'
服务发现
curl-X GET 'http://127.0.0.1:8848/nacos/v1/ns/instance/list?serviceName=nacos.naming.serviceName'
发布配置
curl-X POST "http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=nacos.cfg.dataId&group=test&content=HelloWorld"
获取配置
curl-X GET "http://127.0.0.1:8848/nacos/v1/cs/configs?dataId=nacos.cfg.dataId&group=test"
4. 文档
https://nacos.io/zh-cn/index.html
https://nacos.io/zh-cn/docs/what-is-nacos.html
https://nacos.io/zh-cn/docs/quick-start.html
https://nacos.io/zh-cn/docs/deployment.html
https://github.com/alibaba/nacos
http://dubbo.apache.org/zh-cn/docs/user/references/registry/nacos.html