Nacos 基本操作

概念

Nacos是阿里巴巴的产品,现在是springcloud的一个组件,相比于Eureka更加丰富。

启动 (单机启动)

进入nacos\bin目录,cmd进入控制台,输入startup.cmd -m standalone

浏览器输入地址:http://192.168.0.101:8848/nacos/index.html#/login

默认账号密码均为:nacos

springboot中添加nacos

添加依赖

父工程的pom.xml添加依赖:

xml 复制代码
<!-- 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>

子工程客户端添加依赖:

xml 复制代码
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

修改子工程中的application.yml文件

yaml 复制代码
spring:
    cloud:
      nacos:
        discovery:
          server-addr: localhost:8848

启动测试

分级存储模型

  1. 一级是服务,例如userservice
  2. 二级是集群,例如地点上海或者杭州
  3. 三级是机房,例如杭州的机房部署了userservice服务器

对于同一集群的服务器,消费者会优先调用同一集群的生产者服务器,若同一集群的生产者服务器宕机,则调用其他集群的服务器。

如何修改

在application.xml文件,添加spring.cloud.nacos.discovery.cluster-name属性

查看

负载均衡

设置

修改消费者的apllication.yml,设置Rule

(生产者为userservice,消费者为orderservice)

yaml 复制代码
userservice:
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule

NacosRule 策略:

  1. 优先选择同一集群的服务者实例
  2. 本地集群找不到,才回去其他集群查找
  3. 确定好服务者实例后,采用随机选择

相关策略:

权重控制

若权重设为0,理论上消费者不会调用该生产者,那么即使是在白天,也可以进行服务器的升级

环境隔离

复制命名空间id:24a1cb4c-91be-4177-a914-1fbdd4f898c1

application.yml 中添加 namespace: 24a1cb4c-91be-4177-a914-1fbdd4f898c1

热部署

nacoss上新建配置

文本框内容按照自己需求编写

客户端导入依赖

xml 复制代码
<dependency>
    <groupId>com.alibaba.cloud </groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

从application.yml中抽取需要单独修改的配置,bootstrap的优先级高于application

法一:添加注解

@RefreshScope + @Value("${pattern.deteformat}")

法二:方法中注入

多环境配置共享

优先级:服务名-profile.yaml > 服务名.yaml > 本地配置

如: userservice-dev.yaml > userservice.yaml > application.yaml

相关推荐
小码哥_常4 小时前
MyBatis-Plus:让数据库操作飞起来的神器
后端
2301_811274315 小时前
基于SpringBoot的智能家居管理系统
spring boot·后端·智能家居
AI人工智能+电脑小能手5 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
舒一笑5 小时前
我把设备指纹生成逻辑拆开了:它到底凭什么区分不同设备?
后端·程序员·掘金技术征文
Nicander6 小时前
多数据源下@transcation事务踩坑
java·后端
郑州光合科技余经理6 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
sjsjsbbsbsn7 小时前
大模型核心知识总结
java·人工智能·后端
Moment7 小时前
2026 年,AI 全栈时代到了,前端简历别再只写前端技术了 🫠🫠🫠
前端·后端·面试
白晨并不是很能熬夜8 小时前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio
zshs0008 小时前
#从偶发无字幕到补偿探测链路:一次 B 站字幕导入问题的完整收敛过程
java·后端·重构