SpringCloud 微服务全栈体系(三)
第五章 Nacos 注册中心
- 国内公司一般都推崇阿里巴巴的技术,比如注册中心,SpringCloudAlibaba 也推出了一个名为 Nacos 的注册中心。
一、认识和安装 Nacos
1. 认识 Nacos
- Nacos是阿里巴巴的产品,现在是SpringCloud中的一个组件。相比Eureka功能更加丰富,在国内受欢迎程度较高。

2. 安装 Nacos
2.1 Windows 安装
- 开发阶段采用单机安装即可。
2.1.1 下载安装包
- 在 Nacos 的 GitHub 页面,提供有下载链接,可以下载编译好的 Nacos 服务端或者源代码:
- GitHub 主页:https://github.com/alibaba/nacos
- GitHub 的 Release 下载页:https://github.com/alibaba/nacos/releases

- windows 版本使用
nacos-server-1.4.1.zip包即可。
2.1.2 解压
-
将这个包解压到任意非中文目录下,如图:

-
目录说明:
- bin:启动脚本
- conf:配置文件
2.1.3.端口配置
- Nacos 的默认端口是 8848,如果你电脑上的其它进程占用了 8848 端口,请先尝试关闭该进程。
- 如果无法关闭占用 8848 端口的进程,也可以进入 nacos 的 conf 目录,修改配置文件中的端口:

- 修改其中的内容:

2.1.4 启动
-
启动非常简单,进入 bin 目录,结构如下:

-
然后执行命令即可:
- windows 命令:
startup.cmd -m standalone -
执行后的效果如图:

2.1.5 访问
- 在浏览器输入地址:http://127.0.0.1:8848/nacos 即可:

- 默认的账号和密码都是 nacos,进入后:

2.2 Linux 安装
2.2.1 安装 JDK
-
Nacos 依赖于 JDK 运行,所以 Linux 上也需要安装 JDK 才行。
-
上传 jdk 安装包:

-
上传到某个目录,例如:
/usr/local/ -
然后解压缩:
tar -xvf jdk-8u144-linux-x64.tar.gz
-
然后重命名为 java
-
配置环境变量:
export JAVA_HOME=/usr/local/java
export PATH=$PATH:$JAVA_HOME/bin
- 设置环境变量:
source /etc/profile
2.2.2 上传安装包
- 如图:

- 上传到 Linux 服务器的某个目录,例如
/usr/local/src目录下:

2.2.3 解压
- 命令解压缩安装包:
tar -xvf nacos-server-1.4.1.tar.gz
- 然后删除安装包:
rm -rf nacos-server-1.4.1.tar.gz
- 目录中最终样式:

- 目录内部:

2.2.4 端口配置
- 与 windows 中类似
2.2.5 启动
- 在 nacos/bin 目录中,输入命令启动 Nacos:
sh startup.sh -m standalone
2.3 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>
- 客户端:
<!-- nacos客户端依赖包 -->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
二、服务注册到 nacos
- Nacos 是 SpringCloudAlibaba 的组件,而 SpringCloudAlibaba 也遵循 SpringCloud 中定义的服务注册、服务发现规范。因此使用 Nacos 和使用 Eureka 对于微服务来说,并没有太大区别。
- 主要差异在于:
- 依赖不同
- 服务地址不同
1. 引入依赖
- 在 cloud-demo 父工程的 pom 文件中的
<dependencyManagement>中引入 SpringCloudAlibaba 的依赖:
<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>
- 然后在 user-service 和 order-service 中的 pom 文件中引入 nacos-discovery 依赖:
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
注意:不要忘了注释掉 eureka 的依赖。
2. 配置 nacos 地址
- 在 user-service 和 order-service 的 application.yml 中添加 nacos 地址:
spring:cloud:nacos:server-addr: localhost:8848
注意:不要忘了注释掉 eureka 的地址
3. 重启
- 重启微服务后,登录 nacos 管理页面,可以看到微服务信息:

三、服务分级存储模型
-
一个服务可以有多个实例,例如我们的 user-service,可以有:
- 127.0.0.1:8081
- 127.0.0.1:8082
- 127.0.0.1:8083
-
假如这些实例分布于全国各地的不同机房,例如:
- 127.0.0.1:8081,在上海机房
- 127.0.0.1:8082,在上海机房
- 127.0.0.1:8083,在杭州机房
-
Nacos 就将同一机房内的实例 划分为一个集群。
-
也就是说,user-service 是服务,一个服务可以包含多个集群,如杭州、上海,每个集群下可以有多个实例,形成分级模型,如图:

- 微服务互相访问时,应该尽可能访问同集群实例,因为本地访问速度更快。当本集群内不可用时,才访问其它集群。例如:

- 杭州机房内的 order-service 应该优先访问同机房的 user-service。
1. 给 user-service 配置集群
- 修改 user-service 的 application.yml 文件,添加集群配置:
spring:cloud:nacos:server-addr: localhost:8848discovery:cluster-name: HZ # 集群名称
- 重启两个 user-service 实例后,我们可以在 nacos 控制台看到下面结果:

- 我们再次复制一个 user-service 启动配置,添加属性:
-Dserver.port=8083 -Dspring.cloud.nacos.discovery.cluster-name=SH
- 配置如图所示:

- 启动 UserApplication3 后再次查看 nacos 控制台:

2. 同集群优先的负载均衡
-
默认的
ZoneAvoidanceRule并不能实现根据同集群优先来实现负载均衡。 -
因此 Nacos 中提供了一个
NacosRule的实现,可以优先从同集群中挑选实例。
2.1 给 order-service 配置集群信息
- 修改 order-service 的 application.yml 文件,添加集群配置:
spring:cloud:nacos:server-addr: localhost:8848discovery:cluster-name: HZ # 集群名称
2.2 修改负载均衡规则
- 修改 order-service 的 application.yml 文件,修改负载均衡规则:
userservice:ribbon:NFLoadBalancerRuleClassName: com.alibaba.cloud.nacos.ribbon.NacosRule # 负载均衡规则
四、权重配置
-
实际部署中会出现这样的场景:
-
服务器设备性能有差异,部分实例所在机器性能较好,另一些较差,我们希望性能好的机器承担更多的用户请求。
-
但默认情况下 NacosRule 是同集群内随机挑选,不会考虑机器的性能问题。
-
因此,Nacos 提供了权重配置来控制访问频率,权重越大则访问频率越高。
-
在 nacos 控制台,找到 user-service 的实例列表,点击编辑,即可修改权重:

-
在弹出的编辑窗口,修改权重:

注意:如果权重修改为 0,则该实例永远不会被访问
五、环境隔离
-
Nacos 提供了 namespace 来实现环境隔离功能。
- nacos 中可以有多个 namespace
- namespace 下可以有 group、service 等
- 不同 namespace 之间相互隔离,例如不同 namespace 的服务互相不可见

1. 创建 namespace
- 默认情况下,所有 service、data、group 都在同一个 namespace,名为 public:

- 我们可以点击页面新增按钮,添加一个 namespace:

- 然后,填写表单:

- 就能在页面看到一个新的 namespace:

2. 给微服务配置 namespace
-
给微服务配置 namespace 只能通过修改配置来实现。
-
例如,修改 order-service 的 application.yml 文件:
spring:cloud:nacos:server-addr: localhost:8848discovery:cluster-name: HZnamespace: 492a7d5d-237b-46a1-a99a-fa8e98e4b0f9 # 命名空间,填ID
- 重启 order-service 后,访问控制台,可以看到下面的结果:


- 此时访问 order-service,因为 namespace 不同,会导致找不到 userservice,控制台会报错:

六、Nacos 与 Eureka 的区别
-
Nacos 的服务实例分为两种类型:
-
临时实例:如果实例宕机超过一定时间,会从服务列表剔除,默认的类型。
-
非临时实例:如果实例宕机,不会从服务列表剔除,也可以叫永久实例。
-
-
配置一个服务实例为永久实例:
spring:cloud:nacos:discovery:ephemeral: false # 设置为非临时实例
- Nacos 和 Eureka 整体结构类似,服务注册、服务拉取、心跳等待,但是也存在一些差异:

-
Nacos 与 eureka 的共同点
- 都支持服务注册和服务拉取
- 都支持服务提供者心跳方式做健康检测
-
Nacos 与 Eureka 的区别
- Nacos 支持服务端主动检测提供者状态:临时实例采用心跳模式,非临时实例采用主动检测模式
- 临时实例心跳不正常会被剔除,非临时实例则不会被剔除
- Nacos 支持服务列表变更的消息推送模式,服务列表更新更及时
- Nacos 集群默认采用 AP 方式,当集群中存在非临时实例时,采用 CP 模式;Eureka 采用 AP 方式
相关文章:
SpringCloud 微服务全栈体系(三)
第五章 Nacos 注册中心 国内公司一般都推崇阿里巴巴的技术,比如注册中心,SpringCloudAlibaba 也推出了一个名为 Nacos 的注册中心。 一、认识和安装 Nacos 1. 认识 Nacos Nacos是阿里巴巴的产品,现在是SpringCloud中的一个组件。相比Eure…...
VScode连接的服务器上使用jupyter显示请选择内核源
问题复现 我实在VScode上用ssh-remote连接的服务器,想用.ipynb文件上写东西,结果窗口上方弹出一个输入框,“请键入以选择内核”; 在扩展里找到jupyter更新一下 之前左边的图标是灰色的,后来我下下载了新的版本&#…...
新能源汽车展厅用哪些种类的显示屏比较好?
现在有越来越多的新能源汽车展厅开到了商场、购物中心当中。在新能源汽车展厅中,显示屏已经成为不可或缺的设备设施,可以用来展现产品介绍、优惠信息、文化宣传等。那么新能源汽车展厅的显示大屏用什么屏比较好呢? LED大屏幕:LED显…...
proxmox pve /dev/mapper/pve-root扩容
vgs3 pvs4 vgs5 lvs6 lvremove /dev/pve/data8 lvresize -l 100%FREE /dev/pve/root9 resize2fs /dev/mapper/pve-root 10 history...
【ECS游戏架构】逻辑帧驱动带来的性能和即时性问题分析
1024水一篇~ 个人拙见,如有错误希望大佬拔刀纠正。 根据守望先锋在GDC会议上对ECS架构的描述,所有的系统(system)都是由逻辑帧驱动的:每帧遍历所有的system,并调用system的update()更新游戏世界的状态。 在实际应用中这可能会存…...
数据库监控:关键指标和注意事项
【squids.cn】 全网zui低价RDS,免费的迁移工具DBMotion、数据库备份工具DBTwin、SQL开发工具等 听到模糊的说法“我们的数据库有问题”对于任何数据库管理员或管理员来说都是一场噩梦。有时是真的,有时不是,到底问题出在哪里呢?真…...
高防回源ip被源站拦截怎么办
在进行网站运营过程中,我们经常会遇到DDoS攻击等网络安全威胁。为了保护网站的正常运行,很多企业选择使用高防服务来应对这些攻击。有时候我们可能会遇到一个问题,就是高防回源IP被源站拦截的情况。 那么,当我们发现高防回源…...
关于集群和分布式部署
EJB的RPC是同步调用可实现分布式计算,是SessionBean和EntityBean用的,而JMS是异步调用。RMI,和webservice也可以实现分布式计算。 举例说明,假设我们的系统有三个EJB组件:人事、财务、销售,都是开放远程接口…...
XIlinx提供的DDR3 IP与 UG586
DDR系统需要关注的三样东西:控制器、PHY、SDRAM颗粒,但这是实现一个DDR3 IP所需要的,如果只希望调用IP的话,则只需要调用IP即可,目前时间紧急,我先学一学如何使用IP,解决卡脖子的问题࿰…...
C++数据结构X篇_19_排序基本概念及冒泡排序(重点是核心代码)
文章目录 1. 排序基本概念2. 冒泡排序2.1 核心代码2.2 冒泡排序代码2.3 查看冒泡排序的时间消耗2.4 冒泡排序改进版减小时间消耗 1. 排序基本概念 现实生活中排序很重要,例如:淘宝按条件搜索的结果展示等。 概念 排序是计算机内经常进行的一种操作,其目…...
LeetCode LCR 179. 查找总价格为目标值的两个商品
和为 s 的两个数字 题目链接 LCR 179. 查找总价格为目标值的两个商品 购物车内的商品价格按照升序记录于数组 price。请在购物车中找到两个商品的价格总和刚好是 target。若存在多种情况,返回任一结果即可。 示例 1: 输入:price [3, 9, 12, …...
上架用的SDK三方应用隐私
SDK名称:华为推送 使用目的:用于向华为手机用户推送消息 使用场景:用户账号相关促销活动、消息提醒更新时 信息收集类型:设备相关信息(Android_ID)使用的敏感权限:不涉及 使用的敏感权限&am…...
从REST到GraphQL:升级你的Apollo体验
前言 「作者主页」:雪碧有白泡泡 「个人网站」:雪碧的个人网站 「推荐专栏」: ★java一站式服务 ★ ★ React从入门到精通★ ★前端炫酷代码分享 ★ ★ 从0到英雄,vue成神之路★ ★ uniapp-从构建到提升★ ★ 从0到英雄ÿ…...
Jupyter使用技巧-环境篇
不同于其他IDE,有时会出现找不到文件路径,通常是因为当前工作目录(working directory)不同所导致的。Jupyter Notebook 会在启动时选择一个初始的工作目录,而这个目录可能与你运行 .py 文件时所在的目录不同。 import…...
软件项目管理【UML-组件图】
目录 一、组件图概念 二、组件图包含的元素 1.组件(Component)->构件 2.接口(Interface) 3.外部接口——端口 4.连接器(Connector)——连接件 4.关系 5.组件图表示方法 三、例子 一、组件图概念…...
npm版本错误——npm ERR! code ERESOLVE 解决方法
起因 项目中echart版本过低,导致某些图表不能正确显示,所以大手一挥,将echart版本从4升级到了5, 再去运行项目的时候 就发现项目报错了 npm ERR! code ERESOLVE npm ERR! ERESOLVE unable to resolve dependency tree npm ERR! …...
基于卷积神经网络的乳腺癌分类 深度学习 医学图像 计算机竞赛
文章目录 1 前言2 前言3 数据集3.1 良性样本3.2 病变样本 4 开发环境5 代码实现5.1 实现流程5.2 部分代码实现5.2.1 导入库5.2.2 图像加载5.2.3 标记5.2.4 分组5.2.5 构建模型训练 6 分析指标6.1 精度,召回率和F1度量6.2 混淆矩阵 7 结果和结论8 最后 1 前言 &…...
模式识别——高斯分类器
模式识别——高斯分类器 需知定义特殊情况(方差一致)Sigmoid 需知 所有问题定义在分类问题下,基于贝叶斯决策 定义 条件概率为多元高斯分布,此时观测为向量 X X 1 , X 2 , . . . , X n X{X_1,X_2,...,X_n} XX1,X2,...,Xn…...
LeetCode 15. 三数之和
三数之和 题目链接 15. 三数之和 给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k ,同时还满足 nums[i] nums[j] nums[k] 0 。请 你返回所有和为 0 且不重复的三元组。 **注意:**答案…...
React-native-camera 在小米手机上拍照查看闪退
场景:为实现可拍照和录像的相机用react-native-camera这个库手写一个相机,发现了拍出来的图片在小米10上查看闪退 根据手机后台捕获的错误信息是什么玩意太大了(之前还以为是图片显示组件的问题) 改进:相机吊起的时候…...
Cesium城市白模数据工具包|30城CLT模型一键部署(含北上广深)
温馨提示:文末有联系方式一、产品核心功能概览 本工具包专为CesiumJS开发者设计,提供标准化的城市级白膜三维数据模型及配套发布能力,显著降低三维地理信息平台的初始化门槛。二、覆盖城市范围广泛 完整涵盖全国30个重点城市,包括…...
Python 批量导出数据库数据至 Excel 文件形
简介 langchain专门用于构建LLM大语言模型,其中提供了大量的prompt模板,和组件,通过chain(链)的方式将流程连接起来,操作简单,开发便捷。 环境配置 安装langchain框架 pip install langchain langchain-community 其中…...
Agent智能体开发:基于万象熔炉·丹青幻境构建自主任务执行系统
Agent智能体开发:基于万象熔炉丹青幻境构建自主任务执行系统 最近AI圈子里“智能体”(Agent)这个词特别火,但很多人可能还不太清楚它到底能做什么。简单来说,它不再是那个你问一句、它答一句的聊天机器人,…...
C语言的开始
大家好,我是一名智能制造工程专业的大二学生,目前正在系统学习嵌入式开发、C语言、51单片机等相关技术,同时也在为未来的考研和职业发展做准备。在专业学习中,我逐渐发现编程是智能制造领域的核心能力——无论是工业自动化控制、嵌…...
# 002、智能体基础架构:从LLM到多模态模型的支撑体系
上周调一个视觉问答的Demo,半夜被报警短信吵醒。日志里赫然一行:RuntimeError: Expected tensor for image to be CUDA, but got CPU。就这一行错误,背后是三个小时的多模态数据管道调试——图像在预处理阶段漏了.cuda(),而文本编…...
Python如何实现定时异步任务_结合asyncio与loop.call_later调用
asyncio.call_later不能直接await,因为它返回Handle对象而非Awaitable;正确做法是在回调中用asyncio.create_task启动协程。asyncio.call_later 为什么不能直接 await?因为 loop.call_later 是一个同步注册函数,它不返回协程对象&…...
沈阳户外路灯厂家哪家好
大家好,我是你们的老朋友小李。今天咱们聊聊沈阳的户外路灯市场,尤其是哪家厂家值得信赖。在众多品牌中,中领乾路灯凭借其卓越的产品质量和贴心的服务,逐渐成为了行业的佼佼者。接下来,我会从几个方面来详细分析一下&a…...
大数据知识图谱之深度学习:基于BERT+LSTM+CRF深度学习识别模型医疗知识图谱问答可视化系统
文章目录大数据知识图谱之深度学习:基于BERTLSTMCRF深度学习识别模型医疗知识图谱问答可视化系统一、项目概述二、系统实现基本流程三、项目工具所用的版本号四、所需要软件的安装和使用五、开发技术简介Django技术介绍Neo4j数据库Bootstrap4框架Echarts简介Navicat…...
如何用Tweepy构建强大的Twitter数据分析报告:5个高级搜索聚合技巧
如何用Tweepy构建强大的Twitter数据分析报告:5个高级搜索聚合技巧 【免费下载链接】tweepy Twitter for Python! 项目地址: https://gitcode.com/gh_mirrors/tw/tweepy Tweepy是Python中最流行的Twitter API客户端库,让开发者能够轻松访问Twitter…...
告别提取码困扰:baidupankey让百度网盘资源获取效率倍增
告别提取码困扰:baidupankey让百度网盘资源获取效率倍增 【免费下载链接】baidupankey 项目地址: https://gitcode.com/gh_mirrors/ba/baidupankey 一、用户困境解析:提取码获取的隐性成本 在数字化资源交换日益频繁的今天,百度网盘…...
