【SpringCloud】Nacos

news2025/1/18 6:48:31

文章目录

  • 一、Nacos
    • 1、安装
    • 2、服务注册和发现
    • 3、服务分级存储模型
    • 4、负载均衡策略--NacosRule
    • 5、服务实例的权重设置

一、Nacos

1、安装

官网:https://nacos.io/zh-cn/

在这里插入图片描述

  • 下载
Github主页: https://github.com/alibaba/nacos
Github的Release下载页: https://github.com/alibaba/nacos/releases

在这里插入图片描述

  • 解压
# bin即启动脚本、可执行文件
# conf即配置文件,nacos默认端口8848

在这里插入图片描述

  • 启动

在这里插入图片描述

双击startup.cmd或者执行cmd命令:

//进入bin目录,打开cmd
// -m standalone即单机启动 
startup.cmd -m standalone
  • 启动成功

在这里插入图片描述

  • 登录

在这里插入图片描述

2、服务注册和发现

  • 在cloud-demo父工程中添加spring-cloud-alilbaba的管理依赖:
<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的客户端依赖(此时user、order中的eureka可以注释掉了)
<!-- nacos客户端依赖-->
<dependency>
	<groupId>com.alibaba.cloud</groupId>
	<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
  • 在order和user模块的application.yml文件中,注释eureka地址,添加nacos的地址
server:
  port: 8081
spring:
  application:
    name: userservice  # user服务的服务名称
  cloud:
    nacos:
      server-addr: localhost:8848  # nacos服务端地址
  • 重启order服务,查看nacos,可以看到注册成功

在这里插入图片描述

3、服务分级存储模型

一个服务可以部署多个实例,如果将这多个实例部署到同一个机房,万一这个机房出现意外,则整个集群宕掉。因此考虑将以机房划分集群,如上海集群、杭州集群…

在这里插入图片描述

可以看出,nacos的服务分级模型中,一级是服务、二级是集群、三级是实例。

引入集群的概念,其实是做个划分:服务调用尽可能选择本地集群的服务,跨集群调用延迟较高本地集群不可访问时,再去访问其它集群

在这里插入图片描述

配置集群属性:

点进去一个服务,可以看到它的集群是default,即默认,没有划分集群

在这里插入图片描述

想配置集群属性,可修改application文件

server:
  port: 8081
spring:
  application:
    name: userservice  # user服务的服务名称
  cloud:
    nacos:
      server-addr: localhost:8848  # nacos服务端地址
      discovery:   # 新加集群属性
        cluster-name: HZ # 配置集群名称,也就是机房位置

修改application的集群信息,启动一个userservice实例,再修改,再启动另一个实例:

在这里插入图片描述

刷新nacos,进入userservice服务,可以看到有两个集群,以及集群下的服务实例:

在这里插入图片描述

4、负载均衡策略–NacosRule

现在,user服务的实例被部署到了两个集群中:杭州集群和上海集群。接下来实验order调用user服务时,优先选择本地集群的服务。因此,先给order服务添加一个集群属性:

# 修改order服务的application文件
server:
  port: 8080
spring:
  application:
    name: orderservice  # order服务的服务名称
  cloud:
    nacos:
      server-addr: localhost:8848  # nacos服务端地址
      discovery:   # 新加集群属性
        cluster-name: HZ # 配置成杭州集群,也就是机房位置

重启order服务,查看nacos,发现order的实例已成功位于杭州集群:

在这里插入图片描述

此时,多次访问 http://localhost:8080/order/{orderId},发现控制台上三个服务实例均有日志输出,并没有按照集群来优先选择本地。

在这里插入图片描述

很明显,这是负载均衡默认的轮询机制。接下来修改默认机制:

在order-service中设置负载均衡的IRule为NacosRule,这个规则优先会寻找与自己同集群的服务实例:
userservice:
  ribbon:
    NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule #负载均衡规则,这里之前学Eureka时配置的是随机

# 以上配置即:order调用userservice时,优先选择同集群的userservice实例

此时,再多次调用http://localhost:8080/order/{orderId},发现上海集群的8003实例中,控制台没有日志了。可见现在是优先杭州集群的实例。

在这里插入图片描述

此时,停掉杭州的两个实例:

在这里插入图片描述

再调用http://localhost:8080/order/{orderId},发现请求到了上海集群的userservice的8003实例上。且orderservice控制台输出警告信息A cross-cluster call occurs,即一个跨集群访问发生。

在这里插入图片描述

总结:NacosRule这种负载均衡策略下,优先本地集群的实例,本地的多个可用实例之间则又是随机的策略。

5、服务实例的权重设置

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/556866.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

linux命令行如何查看命令帮助信息

一&#xff0c;简介 “授之以鱼不如授之以渔”&#xff0c;我们再学习linux命令的时候&#xff0c;想查看某个命令的详细说明&#xff0c;有哪些方法呢&#xff1f;本文来介绍一下如何在命令行查找命令的帮助信息。 二&#xff0c;linux命令格式介绍 Linux命令一般由三部分组…

【深度学习】- 作业1: Softmax实现手写数字识别

课程链接: 清华大学驭风计划 代码仓库&#xff1a;Victor94-king/MachineLearning: MachineLearning basic introduction (github.com) 驭风计划是由清华大学老师教授的&#xff0c;其分为四门课&#xff0c;包括: 机器学习(张敏教授) &#xff0c; 深度学习(胡晓林教授), 计算…

【深度学习】 - 作业7: 图像超分辨率重建

课程链接: 清华大学驭风计划 代码仓库&#xff1a;Victor94-king/MachineLearning: MachineLearning basic introduction (github.com) 驭风计划是由清华大学老师教授的&#xff0c;其分为四门课&#xff0c;包括: 机器学习(张敏教授) &#xff0c; 深度学习(胡晓林教授), 计算…

Linux网络编程—Day10

Linux服务器程序规范 Linux服务器程序一般以后台进程形式运行。后台进程又称守护进程。它没有控制终端&#xff0c;因而也不会意外接收到用户输入。 守护进程的父进程通常是init进程&#xff08;PID为1的进程&#xff09;&#xff1b;Linux服务器程序通常有一套日志系统&#…

Android 11.0 系统设置显示主菜单添加屏幕旋转菜单实现旋转屏幕功能

1.前言 在android11.0的系统rom定制化开发中,在对系统设置进行定制开发中,有产品需求要求增加 旋转屏幕功能的菜单,就是在点击旋转屏幕菜单后弹窗显示旋转0度,旋转 90度,旋转180度, 旋转270度针对不同分辨率的无重力感应的大屏设备的屏幕旋转功能的实现, 接下来就来分析…

chatgpt赋能Python-python_dill

Python dill - 更高效&#xff0c;更强大的对象序列化工具 在Python编程中&#xff0c;对象序列化是一个非常常见的操作&#xff0c;它将Python对象转换为可以存储或传输的格式。Python默认提供了pickle模块来实现序列化&#xff0c;但是pickle存在一些限制&#xff0c;比如无…

usb摄像头驱动-core层usb设备的注册

usb摄像头驱动-core层driver.c 文章目录 usb摄像头驱动-core层driver.cusb_bus_typeusb_device_matchusb_uevent usb_register_driver 在ubuntu中接入罗技c920摄像头打印的信息如下&#xff1a; 在内核中&#xff0c;/driver/usb/core/driver.c 文件扮演了 USB 核心驱动程序管…

复现ms17-010漏洞

复现ms17-010 复现条件环境操作效果 让我们来看看“hkl”在干嘛 复现 条件 1.靶机必须为win8以下。 2.靶机必须同攻击机处于相同网段&#xff08;即倒数第二位相同&#xff09;。 3.靶机的445端口必须要开启。 环境 虚拟机kali为攻击机&#xff0c;win7虚拟机为靶机。 kali…

SELECT LAST_INSERT_ID()自增主键冲突或者为0问题

问题 数据库为mysql&#xff1b; mapper.xml文件为mybatis-generator自动生成的&#xff1b; 连接池使用DruidDataSource&#xff1b; 最终生成的insertSelective如下&#xff1a; 出现问题&#xff1a; 主键冲突&#xff1a;[WMyBatisTraceInterceptor:54][com.mysql.jdbc.…

如何定位OOM

造成OOM的原因 定位OOM 针对第一和第二种情况需要定位OOM 系统已经挂了&#xff1a; 通过堆dump文件定位。 当JVM发生OOM时&#xff0c;自动生成DUMP文件&#xff1a; -XX:HeapDumpOnOutOfMemoryError -XX:HeapDumpPath${目录} java -Xms10M -Xmx10M -XX:HeapDumpOnOutOfMemo…

c#中的json数据

JSON数据 数据传输的语言&#xff0c;用于前后端数据交互的语言&#xff0c;注意xml的区别。 json和xml的区别 xml&#xff1a;可扩展标记语言&#xff0c;是一种用于标记电子文件使其具有结构性的标记语言。 json&#xff1a;(JavaScript Object Notation, JS 对象简谱) 是…

昆仲被投企业「鲲游光电」近期完成新一轮数亿元融资,继续致力于探索前沿光电子领域产品与创新应用|昆仲·链

鲲游光电(North Ocean Photonics)是专注于晶圆级光学、光集成领域的高科技企业&#xff0c;总部位于中国上海。依托自身深厚的技术积累、高精度的制造工艺&#xff0c;鲲游光电通过融合集成光学与集成电路的创新思路&#xff0c;致力于探索前沿光子、光电子领域的实现与创新应用…

MyBatis环境搭建配置、增删改查操作、分页、事务操作、动态SQL、缓存机制、注解开发

MyBatis 文章目录 MyBatisXML语言简介用途各部分注解声明元素属性注释CDATA转义字符 搭建环境读取实体类创建实体与映射关系的文件 配置MyBatis创建工具类接口实现 Mybatis工作流程增删改查指定映射规则指定构造方法字段名称带下划线处理条件查询插入数据复杂查询和事务一对多查…

Codeforces Round 860 (Div. 2)

A Showstopper 题意&#xff1a;给你两个长度为n的数组a和b&#xff0c;每次操作你可以互换a[i]与b[i]&#xff0c;问最终能否满足 思路&#xff1a;若a[i]>b[i]&#xff0c;我们就进行操作。这样数组b元素都是较大的&#xff0c; 一定比不操作更优。最后判断是否满足条件…

Python中的异常处理机制

什么是异常与异常处理 异常就是错误 异常会导致程序崩溃并停止运行 能监控并捕获到异常&#xff0c;将异常部位的程序进行修理使得程序继续正常运行 异常的语法结构 try:<代码块1> 被try关键字检查并保护的业务代码except <异常的类型>:<代码块2> # 代码…

Mybatis源码细节探究:sqlSessionFactory.openSession()这个方法到底发生了什么?

给自己的每日一句 不从恶人的计谋&#xff0c;不站罪人的道路&#xff0c;不坐亵慢人的座位&#xff0c;惟喜爱耶和华的律法&#xff0c;昼夜思想&#xff0c;这人便为有福&#xff01;他要像一棵树栽在溪水旁&#xff0c;按时候结果子&#xff0c;叶子也不枯干。凡他所做的尽…

【笔记】【Javascript】浅面了解原型和原型链

前言 原型和原型链是学习前端必备知识笔记中有些个人理解后整理的笔记&#xff0c;可能有所偏差&#xff0c;也恳请读者帮忙指出&#xff0c;谢谢。 免责声明 为了方便&#xff0c;本文中使用的部分图片来自于网络&#xff0c;如有侵权,请联系博主进行删除&#xff0c;感谢其…

C++ 二分查找法 LeetCode:704. 二分查找

class Solution { public:int search(vector<int>& nums, int target) {int length nums.size();//计算容器长度int left 0;//0int right length-1;//5int middle 0;/*while(left<right){middle (leftright)/2;//middle (leftright)>>1;if(nums[middl…

mysql子查询嵌套

目录 前言 一、实际需求解决 1.方式1&#xff1a;自连接 2.方式2&#xff1a;子查询 二、单行子查询 1.操作符子查询 三、相关子查询 四、自定义语句 五、子查询的问题 1.空值问题 2.非法使用子查询 六、多行子查询 七、聚合函数的嵌套使用 八、多行子查询空值问题…

Python爬虫实战——获取指定博主所有专栏链接及博文链接

Python爬虫实战——获取指定博主所有专栏链接及博文链接 0. 前言1. 第三方库的安装2. 代码3. 演示效果 0. 前言 本节学习使用爬虫来爬取指定csdn用户的所有专栏下的文章 操作系统&#xff1a;Windows10 专业版 开发环境&#xff1a;Pycahrm Comunity 2022.3 Python解释器版…