注意: 这篇讲的是Nacos的服务注册和服务拉取的作用。
Nacos是阿里巴巴的产品,也是注册中心也有负载均衡功能,现在是SpringCloud中的一个组件,相比较而言比Eureka功能更丰富。在国内更加欢迎。
nacos官网
1.进入官网

2.找到下载功能

3.找到你想下载的版本

nacos14.1安装包 提取码:0221
1.解压

2.默认端口是8848,如果你要改端口在 conf -> application.properties

3.启动
注意: 默认账号密码都是:nacos
//启动命令 在bin目录下启动
startup.cmd -m standalone-m:模式(单机模式、集群模式)
standalone:单机模式


1.服务注册时,配置服务是临时实例还是非临时实例,在服务的yml服务配置
springcloud:nacos:server-addr: localhost:8848 # nacos服务地址discovery:ephemeral: false # 默认是临时实例,true:临时实例,false:非临时实例
2.可视化界面查看实例类型


1.在父工程pom文件添加依赖
com.alibaba.cloud spring-cloud-alibaba-dependencies 2.2.5.RELEASE pom import
2.在子工程pom文件添加依赖(订单服务)
com.alibaba.cloud spring-cloud-starter-alibaba-nacos-discovery
3.yml文件配置(订单服务)
spring:cloud:nacos:server-addr: localhost:8848 # nacos服务地址,默认地址
4.查看启动服务的信息

1.多级存储模式逻辑图

2.yml文件配置集群
spring:cloud:nacos:server-addr: localhost:8848 # nacos地址discovery: cluster-name: CX #集群名称,CX是曹县的集群
例如:订单服务要访问用户服务的集群。但是想优先访问CX集群的用户服务。
(1) yml文件配置(订单服务)
spring:cloud:nacos:server-addr: localhost:8848 # nacos地址discovery: cluster-name: CX #集群名称,CX是曹县的集群
(2) 配置Ribbon的规则(订单服务)
userservice:ribbon:NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # Nacos负载均衡规则(优先访问同集群的服务,随机访问,找不到同集群的会报警告,然后去找其他集群)
例如:部署用户服务的服务器,有的好,有的坏,那我们想让好的服务器接受的请求多一些该怎么办呢?
nocos控制台设置权重(权重越大访问越多,权重为0,不会被访问)



Nacos中服务存储和数据存储的最外层都是一个名为namespace的东西,用来做最外层隔离。可以用于比如生产环境、测试环境、开发环境这种进行隔离,还有根据集群的地域的不同进行隔离。
1.隔离逻辑图

2.查看服务所属的命名空间和组

3.新建命名空间

4.把指定服务加入某个命名空间,配置yml文件
spring:cloud:nacos:server-addr: localhost:8848 # nacos服务地址discovery:namespace: 4d6ce343-9e1b-44df-a90f-2cf2b6b3d177 # dev环境,值是命名空间的id,配置完这个服务就属于dev环境的命名空间了,其他命名空间访问不到
共同点
①都支持服务的注册和拉取。
②都支持服务提供者以心跳检测来判断是否健康(临时实例)。
不同点
①nacos支持注册中心主动询问服务提供者的状态(非临时实例)。
②nacos支持注册中心消息变更主动推送。
③心跳不正常会被剔除(临时实例)。