目录
Nacos介绍
Nacos安装
下载和安装
修改端口
启动
服务注册与发现
导入Nacos管理依赖
导入服务依赖
配置Nacos的服务地址
启动服务,查看已注册的服务
服务分级存储模型
分级存储模型介绍
具体结构
配置实例集群
同集群优先的负载均衡策略
服务权重配置
点击编辑
配置所需的权重
环境隔离
namespace介绍
创建namespace
查看
Nacos介绍
Nacoshttps://nacos.io/
Nacos 是一个功能强大的服务发现和配置管理平台,它可以简化微服务架构中的服务注册、配置管理和服务发现等任务,提供了一致性、高可用性和可扩展性的解决方案。通过使用 Nacos,可以更好地管理和协调分布式系统中的各个组件和服务实例。
Nacos是阿里巴巴的产品,现在是SpringCloud中的一个组件。
Nacos安装
下载和安装
下载地址:
Nacoshttps://github.com/alibaba/nacos/releases 这里展示win版的Nacos,下载过程省略,将下载好的压缩包解压,打开bin目录,可以看到Nacos的启动文件
修改端口
nacos默认端口:8848(可能这就是阿里巴巴的幽默吧,成功人士的标配),如需修改,可以在conf文件下的application.properties文件中修改
启动
打开命令窗口,输入启动命令
startup.cmd -m standalone
出现如下界面,说明启动成功
输入窗口中显示的控制台地址,即可进入nacos控制台登录页面,默认账号密码都是:nacos
进入Nacos控制台主页
Nacos服务注册与发现
nacos的服务注册方式大体与eureka相同,详情请查看我之前发布的:1.2 eureka注册中心,完成服务注册https://blog.csdn.net/hkzuz/article/details/132007406?spm=1001.2014.3001.5501
在父工程导入Nacos的管理依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2.2.6.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
在需要注册到Nacos的服务中导入服务依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
在需要注册到Nacos的服务中的配置文件中配置Nacos的服务地址
spring:
cloud:
nacos:
server-addr: localhost:8848 #nacos服务地址
启动服务后,即可在Nacos的服务列表看到已注册的服务
Nacos的服务分级存储模型
分级存储模型介绍
一个服务可以有多个实例,在Nacos中,点击服务的详情即可查看
假如实例分布于全国各地的不同机房,Nacos就将同一机房内的实例 划分为一个集群。一个服务可以包含多个集群。
具体结构
微服务互相访问时,应该尽可能访问同集群实例,因为本地访问速度更快。当本集群内不可用时,才访问其它集群。
配置实例集群
配置集群操作,只需要在对应服务配置文件中修改即可
cloud:
nacos:
server-addr: localhost:8848 #nacos服务地址
discovery:
cluster-name: USER1 #集群名称
重新启动服务,在Nacos中可以看到实例在不同的集群(在重启服务后,若看到Nacos中存在空集群或默认集群且为空时,可以重启Nacos,或许可以解决)
在服务列表可以看到当前user服务具有3个集群
点击详情可查看
同集群优先的负载均衡策略
此为Nacos的同集群优先访问的负载均衡规则,同集群内随机访问
userservice: #要做配置的服务名称
ribbon:
NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则
服务权重配置
实际部署中,有这样的情况,不同服务器有性能差异,因此要为不同的服务器配置访问权重来控制访问频率,在Nacos中可以选择服务实例直接配置
点击编辑按钮
配置所需的权重
如下图,配置权重为0.1,和别的实例的访问频率就会是1:10
环境隔离
namespace介绍
Nacos不仅是注册中心,还是数据中心,
Nacos提供了namespace来实现环境隔离功能。
- nacos中可以有多个namespace
- namespace下可以有group、service等
- 不同namespace之间相互隔离,例如不同namespace的服务互相不可见
创建namespace
在nacos的命名空间中,可以查看已有空间及其ID,点击添加命名空间按钮可以创建新空间
输入空间名和描述,即可创建成功
将服务放置到空间中,在配置文件中添加配置
spring:
cloud:
nacos:
server-addr: localhost:8848
discovery:
cluster-name: USER1
namespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 # 命名空间,填ID
在服务列表可以查看空间并选择
查看
重启服务,查看空间内是否有对应服务。选择USER空间,可以看到对应的服务