【微服务】Nacos

一、安装

1、官网地址:https://nacos.io/download/nacos-server/

2、启动:找到bin目录下的startup.cmd双击启动,或者打开一个命令窗口输入:

java 复制代码
startup.cmd -m standalone

双击启动后如下:可以访问控制台地址

访问后的地址如下:

登录:默认账号和密码都是nacos

二、注册

1、在cloud-demo父工程中添加spring-cloud-alibaba的管理依赖

java 复制代码
            <!--nacos的管理依赖-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>2.2.5.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

2、注释掉order-service和user-service中原有的eureka依赖

3、添加nacos的客户端依赖

java 复制代码
        <!--nacos的客户端依赖-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>



成功负载均衡

三、Nacos服务分级存储模型

1、修改spplication.yml,添加如下内容

修改成HZ后直接可以启动userApplication和userApplication2,此时这两个就在HZ集群

修改成SH,在启动UserApplication3,此时UserApplication3就在SH集群。

2、服务台可以看到集群变化

四、修改集群负载均衡规则NacosRule

orderService同样设置在HZ集群(8081 8082),看调用时是否优先选择本地集群。

但是此发送请求发现默认选择轮询 ,即8081,8082,8083无论集群内还是集群外,都接收到了请求。如何解决:

1、修改order-service中的application.yml,设置集群为HZ(如上)

2、在order-service中设置负载均衡的IRule为NacosRule,这个规则就会优先寻找与自己相同集群的服务

java 复制代码
userservice:
  ribbon:
      NFLoadBalancerRuleclassName: com.alibaba.cloud.nacos.ribbon.NacosRule

发送五条请求,发现都在同一集群的8081 8082之下,而8083暂时没有


NacosRule 先选择本地集群,在本地集群中随机访问,将8081 8082停止服务,再发送请求:

3、注意将user-service的权重都设置为1

五、根据权重负载均衡

1、Nacos控制台可以设置实例的权重值,首先选中实例后面的编辑按钮

Nacos控制台可以设置实例的权重值,O~1之间同集群内的多个实例,权重越高被访问的频率越高权重设置为0则完全不会被访问

六、环境隔离-namespace

Nacos中服务存储和数据存储的最外层都是一个名为namespace 的东西,用来做最外层隔离

1、创建命名空间

2、修改服务的命名空间

修改order-service的application.yml,添加namespase

此时再从orerservice发送请求,8081 8082 8083均收不到,因为被命名空间隔离了

七、Eureka和Nacos对比

设置临时实例(默认是true),停止orderservice,此时在dev中直接消失

再设置为非临时实例(false),重启orderservice,再次检查状态

此时再主动停止该服务,爆红后但还是存在,不会删除,重启后仍旧存在

1、Nacos与eureka的共同点

  • 都支持服务注册和服务拉取
  • 都支持服务提供者心跳方式做健康检测

2、Nacos与Eureka的区别

  • Nacos支持服务端主动检测提供者状态:临时实例采 用心跳模式,非临时实例采用主动检测模式
  • 临时实例心跳不正常会被剔除,非临时实例则不会被剔除
  • Nacos支持服务列表变更的消息推送模式,服务列表更新更及时
  • Nacos集群默认采用AP方式,当集群中存在非临时实例时,采用CP模式;Eureka采用AP方式
相关推荐
若兰幽竹几秒前
【从零开始编写数据库系统:架构设计与实现】第5章:查询执行引擎与火山模型
数据库·架构·数据库内核·toydb
keep one's resolveY几秒前
SpringBoot实现重试机制的四种方案
java·spring boot·后端
逻辑诗篇14 分钟前
破核拆解:PCIE719——基于Xilinx Zynq UltraScale+的高性能SAS扩展卡设计
fpga开发·架构
天空属于哈夫克334 分钟前
企业微信API常见的错误和解决方案
java·数据库·企业微信
wenzhangli742 分钟前
Ooder A2UI 核心架构深度解析:WEB 拦截层的设计与实现
前端·架构
福大大架构师每日一题1 小时前
openclaw v2026.4.24 发布:Google Meet 深度集成、DeepSeek V4 上线、浏览器自动化与插件架构全面升级
运维·架构·自动化·openclaw
身如柳絮随风扬1 小时前
深度解析 Elasticsearch 搜索服务:核心原理、架构与优化实践
大数据·elasticsearch·架构
摇滚侠1 小时前
VMvare 虚拟机 Oracle19c 安装步骤,远程连接 Oracle19c,百度网盘安装包
java·oracle
梁萌1 小时前
idea报错找不到XX包的解决方法
java·intellij-idea·启动报错·缺少包
Agent产品评测局2 小时前
生产排期与MES/ERP系统打通,实操方法详解 —— 2026企业级智能体自动化选型与实战指南
java·运维·人工智能·ai·chatgpt·自动化