五、Nacos

news2025/7/12 7:34:44

文章目录

  • 一、安装nacos
    • 1.压缩包下载地址
    • 2.nacos 中修改端口(8848 端口被占用需要修改)
    • 3.启动 nacos:
  • 二、nacos项目环境配置
  • 三、nacos服务分级存储模型
  • 四、NacosRule 实现负载均衡
  • 五、服务实例的权重设置
  • 六、nacos注册中心

一、安装nacos

1.压缩包下载地址

https://github.com/alibaba/nacos/releases

压缩包解压:
在这里插入图片描述

2.nacos 中修改端口(8848 端口被占用需要修改)

进入 conf:
在这里插入图片描述
进入 application.properties:
在这里插入图片描述
端口位置:
在这里插入图片描述

3.启动 nacos:

进入bin:
在这里插入图片描述
打开命令控制台:
在这里插入图片描述
执行命令:

startup.cmd -m standalone

在这里插入图片描述
输入 Console 中的地址,对nacos进行访问(账号和密码都是 nacos):
在这里插入图片描述

二、nacos项目环境配置

在 cloud-demo 父工程的 pom.xml 中添加spring-cloud-alibaba 的管理依赖:

<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>

注释掉 order-service 和 user-service 中原有的 eureka 依赖,添加 nacos 的客户端依赖:。

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

在 order-service 和 user-service 的 application.yml,添加 nacos 地址:

spring:
  cloud:
    nacos:
      server-addr: localhost:8848

启动项目:
在这里插入图片描述

三、nacos服务分级存储模型

在这里插入图片描述
修改 application.yml 配置文件:

spring:
  cloud:
    nacos:
      server-addr: localhost:8848
      discovery:
         cluster-name: HZ  #集群位置,杭州 HZ

服务跨集群调用问题:

服务调用尽可能选择本地集群的服务,跨集群调用延迟较高。
本地集群不可访问时,再去访问其他集群。

四、NacosRule 实现负载均衡

1、修改order-service中的application.yml,设置集群为HZ,一个user-service:8081中的application.yml,设置集群为HZ,另一个user-service:8082中的application.yml,设置集群为SZ。
2、在order-service中设置负载均衡的IRule为NacosRule,这个规则优先会寻找与自己同集群的服务:

userservice:
	ribbon:
    	NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule

3、NacosRule负载均衡策略:

优先选择同集群服务实例列表。
本地集群找不到提供者,才去其他集群寻找,并且会报警告。
确定了可用实例列表后,再采用随机负载均衡策略挑选实例。

五、服务实例的权重设置

在Nacos控制台可以设置实例的权重值,首先选中实例后面的编辑按钮:
在这里插入图片描述
将权重设置为0.1,测试可以发现8081端口被访问到的频率大大降低:
在这里插入图片描述
实例权重控制:

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

六、nacos注册中心

在这里插入图片描述
1、服务提供者向注册中心nacos注册服务信息,服务消费者从注册中心nacos定时(30秒)拉取服务,并将拉取的服务缓存在服务列表中,然后服务消费者再远程调用服务。

2、健康检测:划分为临时实例和非临时实例

  • 临时实例:采用心跳检测,服务提供者每隔一段时间发一个请求给注册中心,表示处于健康状态。要是注册中心未检测到服务提供者发来的请求,则会将该服务者剔除。
  • 非临时实例:由注册中心nacos主动询问服务者是否处于健康状态,当服务提供者未处于健康状态,注册中心nacos会对该服务提供者标记不健康状态,并等待服务提供者恢复健康。

3、服务提供者如何知道服务提供者是否不健康(挂掉、宕机)?

注册中心nacos主动推送变更消息,当服务提供者不健康,注册中心nacos会及时向服务消费者提示,服务消费者会及时更新服务列表。

4、通过配置来修改临时实例和非临时实例:

spring:
	cloud:
		nacos:
			discovery:
				ephemeral: false #设置为非临时实例

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

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

相关文章

LeetCode HOT 100 —— 33.搜索旋转排序数组

题目 整数数组 nums 按升序排列&#xff0c;数组中的值 互不相同 在传递给函数之前&#xff0c;nums 在预先未知的某个下标 k&#xff08;0 < k < nums.length&#xff09;上进行了 旋转&#xff0c;使数组变为 [nums[k], nums[k1], …, nums[n-1], nums[0], nums[1], ……

Hive之存储和压缩

Hive系列 第十章 存储和压缩 10.1 首先看一下Hadoop中的压缩 10.1.1 基本概念 1、概念 压缩是一种通过特定的算法来减小计算机文件大小的机制。这种机制是一种很方便的发明&#xff0c;尤其是对网络用户&#xff0c;因为它可以减小文件的字节总数&#xff0c;使文件能够通过…

Linux-yum

Linux下的开发工具即配置基本都要自己手动&#xff0c;和Windows一键式安装相比&#xff0c;Linux软件的安装要复杂很多。 centos 7下&#xff0c;基本的安装方式有三种&#xff1a; 1.源码安装——挺常用的&#xff0c;但是复杂&#xff0c;对初学者来说可以忽略。 2.rpm包安…

FFmpeg的makefile逻辑分析

在开始分析之前&#xff0c;讲一个 makefile 的调试技巧&#xff0c;推荐阅读《如何调试MAKEFILE变量》 make -f Makefile -f vars.mk HOSTPROGS这里我对 vars.mk 做了点修改&#xff0c;因为源 vars.mk 没处理特殊字符&#xff0c;直接 echo 会报错。ffmpeg 的 makefile 的变…

改进粒子滤波的无人机三维航迹预测方法附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;修心和技术同步精进&#xff0c;matlab项目合作可私信。 &#x1f34e;个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知。 更多Matlab仿真内容点击&#x1f447; 智能优化算法 …

某公司常见题刷题笔记

LeetCode搞起来&#xff0c;虽说和实际业务没啥联系&#xff0c;但现在就卷起来了&#xff0c;没办法被迫卷起来。 1&#xff0c;滑动平均值&#xff0c;官网 给定窗口大小size&#xff0c;然后每次增加一个值value放入窗口&#xff0c;求此窗口内的平均值 class MovingAver…

李宏毅:Life Long Learning

Life Long Learing 也是continual Learning&#xff0c;也是incremental learning 目录 Life-Long Learning vs Transfer Learning Evaluation Research Directions Selective Synaptic Plasticity——Regulization Based Additional Neural Resourcr Allocation Memo…

Python简介-Python3及环境配置

Python简介 Python是一种跨平台的计算机程序设计语言。 是一个高层次的结合了解释性、编译性、互动性和面向对象的脚本语言。最初被设计用于编写自动化脚本(shell)&#xff0c;随着版本的不断更新和语言新功能的添加&#xff0c;越多被用于独立的、大型项目的开发。 Python语…

MFC的YUV播放器实现

MFC的YUV播放器实现 文章目录MFC的YUV播放器实现一、主要参考链接二、开发踩坑记录1、Gdiplus 绘图前置条件2、播放时点击滑竿能精准跳转3、鼠标悬停在滑竿上时显示预览小窗口本文记录使用MFC编写一个YUV播放器的过程&#xff0c;尽量实现播放器都有的常用功能。功能参考与网上…

四旋翼无人机学习第9节--OpenMV以及WIFI电路、供电电路再分析

文章目录0、参考与学习1、OpenMV插座电路2、OpenMV供电电路3、ESP8266电路分析3.0 绘制分享3.1 模块正面图3.2 模块背面图3.3 模块引脚介绍3.4 模块模式选择3.5 芯片手册参考电路4、供电电路分析4.1 电池接口与电源开关部分4.2 usb供电电路与电池电压降压电路4.3 5V降3.3V电路4…

[论文精度|博士论文]非结构环境下病虫害识别方法研究

概述 提出一种基于级联卷积神经网络的植物病害识别方法提出一种融合农田多源环境信息的害虫监测方法提出一种新的目标检测损失函数解决特征冲突问题 本文研究的主要方面在于特征提取。&#xff08;其他部分沿用目前最全面的公开数据和病虫害数据以及最先进的开源算法&#xf…

30岁之后身体还能像年轻的时候一样撸代码吗?

在IT圈流传着一句话&#xff0c;程序员吃的是青春饭。很多人认为&#xff0c;30岁是个阶段&#xff0c;在这个阶段后就需要往管理方向转型。因为在30岁之后身体再也不能像年轻的时候一样熬夜撸代码&#xff0c;而且继续从事一线开发的待遇也不如管理层优厚。至于转管理层失败的…

redis缓存一致性以及解决方案

一致性问题&#xff1a; 首先要到redis里面读取缓存&#xff0c;如果没有缓存&#xff0c;那么就到mysql里面去取数据&#xff0c;并且将其放置在缓存中 关于解决缓存一致性的问题&#xff0c;不难想到主要有两种解决方案&#xff0c;双更模式和删除模式 ** 双更模式&#xf…

【JVM】native关键字的使用

native关键字的使用一、JVM体系结构二、native是什么&#xff1f;三、native能干什么&#xff1f;四、native怎么使用&#xff1f;五、native总结在研读**《深入理解Java虚拟机》这本书时&#xff0c;看到 Java 虚拟机运行时数据区中有关本地方法栈**&#xff08;Native Method…

鲜花在线销售平台的设计与实现/鲜花商城/网上花店管理系统

摘 要 为了解决客户便捷地在网上购物&#xff0c;本文设计和开发了一个鲜花在线销售平台。本系统是基于web架构设计&#xff0c;SSM框架&#xff0c;javascript技术的前台页面设计与实现&#xff0c;使用Mysql数据库管理&#xff0c;综合采用java模式来完成系统的相关功能。主…

【GlobalMapper精品教程】028:栅格计算器的使用方法总结

文章目录 一、栅格计算器简介二、栅格计算器应用举例1. 归一化植被指数NDVI2. 归一化水体指数NDWI3. 归一化建筑指数NDBI一、栅格计算器简介 GlobalMapper中也提供了栅格计算器工具,可以方便的进行栅格计算、波段计算、指数计算等,使用方法有点儿像Envi软件。 用户可以使用系…

世界杯来了,让 Towhee 带你多语言「以文搜球」!

四年一度的世界杯已正式拉开战幕&#xff0c;各小组比赛正如火如荼地进行中。在这样一场球迷的盛宴中&#xff0c;不如让 Towhee 带你「以文搜球」&#xff0c;一览绿茵场上足球战将们的风采吧&#xff5e; 「以文搜球」是跨模态图文检索的一部分&#xff0c;如今最热门的跨模…

Leetcode刷题Day5休息 Day6----------哈希表

Leetcode刷题Day5休息 & Day6----------哈希表 1. 哈希表理论基础 数组、Set、Map 如果数据量小------------数组 如果数据量大------------Set 如果有Key、value------------Map 文章讲解&#xff1a;https://programmercarl.com/%E5%93%88%E5%B8%8C%E8%A1%A8%E7%90%86…

【雷达检测】基于复杂环境下的雷达目标检测技术(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客 &#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜…

数据之道读书笔记-06面向“自助消费”的数据服务建设

数据之道读书笔记-06面向“自助消费”的数据服务建设 数据底座建设的目标是更好地支撑数据消费&#xff0c;在完成数据的汇聚、整合、联接之后&#xff0c;还需要在供应侧确保用户更便捷、更安全地获取数据。一方面业务人员希望尽可能快速地获取各种所需的数据&#xff0c;另一…