在微服务架构里,注册中心(像 Nacos、Eureka、Consul 等)是服务发现与治理的核心。可要是注册中心突然宕机,微服务间的远程调用还能顺利进行吗?这是面试时很常被问到的问题,下面我们就来深入剖析。

一、远程调用的 “两次请求” 与实例缓存的引入

在没有实例缓存的情况下,微服务每次发起远程调用,大致要经历以下两次请求

  1. 请求注册中心,获取目标服务的地址列表:服务消费者得先去注册中心查询,找到自己要调用的服务提供者都有哪些实例,以及这些实例对应的网络地址。
  2. 向目标服务的具体地址发送请求:拿到地址列表后,消费者会挑选其中一个地址,向对应的服务提供者发送实际的业务请求。

不过,这种每次调用都进行两次请求的方式,会让性能大打折扣。为了解决这个问题,实例缓存就应运而生了。实例缓存的作用是在服务消费者本地,同步并实时更新注册中心里的服务实例信息。有了它,服务消费者不用每次调用都去注册中心查询,能直接从本地缓存里获取目标服务的地址,从而提升调用效率。

二、注册中心宕机时,远程调用能否成功?

注册中心宕机后,远程调用是否能成功,关键要看服务消费者本地有没有目标服务的实例缓存

场景一:服务消费者已有目标服务的实例缓存

比如 “订单” 服务之前调用过 “商品” 服务,此时 “订单” 服务本地已经缓存了 “商品” 服务的实例地址。
由于实例缓存还存在,“订单” 服务发起远程调用时,就不再依赖注册中心了。它会直接从本地缓存里取出 “商品” 服务的地址,然后发送请求,所以远程调用能成功

这也体现出实例缓存的重要性,它让微服务在注册中心短暂不可用的时候,依然能保证服务间调用的连续性,增强了系统的容错能力。

场景二:服务消费者无目标服务的实例缓存

要是 “订单” 服务是第一次发起对 “商品” 服务的远程调用,也就是之前从来没有调用过 “商品” 服务,本地没有 “商品” 服务的实例缓存。
这种情况下,“订单” 服务要发起远程调用,就必须依赖注册中心去获取 “商品” 服务的地址列表。但现在注册中心已经宕机,“订单” 服务没办法获取到目标服务的地址,所以远程调用不能成功

三、总结

注册中心宕机后,远程调用是否能成功,取决于服务消费者本地是否有目标服务的实例缓存:

  • 若有缓存(之前调用过目标服务),远程调用能成功,因为可以从本地缓存获取服务地址,不依赖注册中心。
  • 若没有缓存(首次调用目标服务),远程调用会失败,因为获取服务地址必须依赖注册中心。

由此可见,实例缓存是微服务架构中提升远程调用性能、增强系统容错性的关键机制,它在注册中心和服务消费者之间,搭建了一道 “缓冲屏障”,让系统在注册中心出现异常时,仍能维持一定程度的服务调用能力。

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

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《用 Python 和 Matplotlib 绘制折线图:从入门到实战的可视化指南》

《用 Python 和 Matplotlib 绘制折线图:从入门到实战的可视化指南》 一、引言:数据可视化的力量,从一张折线图开始 在我多年的开发与教学经历中,最常被问到的问题之一是:“如何让数据更直观?”我的答案始终如一:用图说话。而在众多图表类型中,折线图以其简洁、清晰的…

Seate的XA模式和AT模式

目录 一、XA模式 【1】两阶段提交 【2】Seata的XA模型 【3】优缺点 【4】实现XA模式 二、AT模式 【1】Seata的AT模型 【2】AT与XA的区别 【3】脏写问题 【4】优缺点 【5】实现AT模式 一、XA模式 XA 规范 是 X/Open 组织定义的分布式事务处理(DTP&#xf…

CTFHub SSRF通关笔记6:Gopher Redis原理详解与渗透实战

目录 一、SSRF Gopher Redis 1、功能简介 2、攻击原理 (1)SSR的作用 (2)Gopher 协议特性 (3)攻击 Redis 步骤 二、gopherus 1、功能简介 2、攻击Redis服务方法 三、Gopherus安装 1、源码下载 2…

数据结构之二叉树(2)

数据结构之二叉树(2)1.二叉树的存储结构2.实现顺序结构二叉树2.1何为堆2.2堆的性质2.3堆的定义2.3堆的初始化与销毁3.1向上调整算法3.2向下调整算法4.入堆5.出堆让花成花,让树成树上一次我们学习了树的分类,并初步了解了二叉树。今…

Linux操作系统之Ubuntu

Ubuntu是基于Debian的开源Linux发行版,由Canonical公司维护,以用户友好性和稳定性著称。它广泛应用于个人电脑、服务器及云计算环境,支持多种硬件架构。Ubuntu的特点Ubuntu提供定期更新版本(每6个月)和长期支持版本&am…

kotlin的函数前面增加suspend关键字的作用

deepseek回答: Kotlin中suspend关键字的作用详解 核心作用 suspend关键字用于标记‌挂起函数‌,使其能够在协程中实现非阻塞的异步操作。 suspend关键字的本质作用 suspend关键字的主要作用是‌标记一个函数为挂起函数‌,使其能够在协程中使用…

Vibe Coding实战项目:用Qwen3-Coder做了个AI跳舞视频生成器

大家好,这里是K姐。 一个 Vibe Coding 的探索者。 前段时间发现通义发起了一个Qwen3-Coder挑战赛,最高奖金有10000元,研究了一下,我发现这个赛道太宽了,不限项目,用 AI Coding 做数据分析、个人Blog、抓取…

Kafka面试精讲 Day 13:故障检测与自动恢复

【Kafka面试精讲 Day 13】故障检测与自动恢复 在“Kafka面试精讲”系列的第13天,我们将深入探讨 Kafka 高可用体系中的关键一环:故障检测与自动恢复机制。作为分布式系统的核心能力,Kafka 如何在 Broker 宕机、网络分区或磁盘故障时快速感知…

【前沿技术拓展Trip Two】具身智能

具身智能(Embodied AI)的认识,进展,以及为何难以实现 在讲具身智能之前,我们不得不先行介绍一下离身智能与离身认识系统这两个极其相关且更加常见的概念 离身认识系统 其实目前绝大多数的AI,例如DeepSeek&a…

使用electron将vue3网页项目包装成pc客户端

一、准备前工作在项目的根目录 打开命令行工具 安装四个依赖库安装报错的话二、准备工作完成之后,在项目根目录需要有俩个文件在项目根目录创建electron文件夹在vite.config.js中添加配置项在package.json中添加配置项运行命令 npm run electron:build 打包关于mac&…

基于安全抽象模型(SAM)的汽车网络安全防御与攻击分析

摘要自动驾驶汽车比以往任何一种个人出行交通工具都具有更大的受攻击可能性。这主要是因为这类汽车对通信有极高的需求,一方面是出于功能和安全方面的考虑,另一方面则是为了满足舒适性需求。无人驾驶汽车需要与周围环境进行通信的接口、直接连接&#xf…

线扫相机不出图原因总结

1、帧触发信号有问题 线扫相机出图由帧信号决定开始采集,如果没有帧信号线扫相机无法识别开始信号,所以不出图 1)没有给相机帧信号 帧信号是一个短暂的脉冲信号,持续时间不要太长,相机能识别就可以,一般由plc或者控制卡的数字量输出口触发,可以通过监测数字量输出口来确…

开发避坑指南(46):Java Stream 对List的BigDecimal字段进行求和

需求 对int,long类型的数据求和直接用stream().mapToInt()、stream().mapToDouble(),可是没有stream().mapToBigDecimal()这样的方法,那么如何用stream对List的BigDecimal字段进行求和? 代码实现 直接上代码 public class OrderIn…

pycharm如何处理python项目间引用

1. 如何在pycharm中将其它项目添加到打开的项目中 如图所示:文件->打开->附加(Attach)即可2.如何引用:直接作为一个普通package引用即可 from attack_projectxxx.modulexxx import xxx3.pyinstaller如何编译这种引用其它项目的可执行文…

家庭劳务机器人发展阶段与时间预测

家庭劳务机器人大规模进入家庭不会是一个单一的时间点,而是一个分阶段、渐进式的过程。我们可以将这个进程分为以下几个阶段,并对每个阶段的时间线进行预测:第一阶段:单一功能机器人普及(现在 - 2025年)这个…

Zynq开发实践(FPGA之spi实现)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】虽然串口用的地方比较多,实现起来也比较简单。但是串口本身速度比较慢,不利于高速数据通信。而且单个串口没有办法和很多芯片…

指甲打磨机/磨甲器MCU控制方案开发,轻松解决磨甲问题

美甲打磨机/指甲打磨机核心功能需求 1. 基础功能 无级调速(5,000-30,000 RPM,PWM控制) 正反转切换(可选,用于抛光/去角质) 按键锁/防误触(长按3秒解锁) 锂电池管理(3.7V单节,带充电指…

临床数据挖掘与分析:利用GPU加速Pandas和Scikit-learn处理大规模数据集

点击 “AladdinEdu,同学们用得起的【H卡】算力平台”,注册即送-H卡级别算力,80G大显存,按量计费,灵活弹性,顶级配置,学生更享专属优惠。 摘要 随着电子健康记录(EHR)的普…

二进制安装MySQL 8.0指南:跨平台、自定义数据路径、安全远程访问配置

二进制安装 MySQL 8.0 在生产或测试环境中,我们常常希望避免包管理器带来的依赖和交互问题,尤其是当系统自带版本过旧或安装过程频繁弹窗时。此时,使用 MySQL 官方提供的二进制压缩包(Generic Linux Binary) 进行安装…

Z检验与T检验的区别与联系:原理、公式和案例全解

Z检验与T检验全解析:原理、区别与实际案例 统计学的核心任务之一,就是通过有限的样本数据去推断总体特征。在这一过程中,假设检验成为了最常见的工具。而在众多检验方法中,Z检验与T检验几乎是入门必学,也是应用最广泛的…