架构师面试(六):熔断和降级
问题
在千万日活的电商系统中,商品列表页服务通过 RPC 调用广告服务;经过统计发现,在最近10秒的时间里,商品列表页服务在对广告服务的调用中有 98% 的调用是超时的; 针对这个场景,下面哪几项的说法是正确的?
A. 商品列表页服务需要触发对广告服务的调用熔断,来防止自身资源被耗尽,目的是对自身进行保护;
B. 商品列表页服务需要触发对广告服务的调用熔断,同时可以向用户返回默认的广告页面,来进行业务的降级处理;
C. 如果商品列表页服务没有触发对广告服务的调用熔断,很可能会造成整个电商系统的雪崩;
D. 基于这个案例说明,熔断和降级都是保证服务柔性可用的有效手段,降级不能独立使用。
解析
A 选项: 【商品列表服务】调用【广告服务】,有98%调用是超时的,如果继续调用,大概率仍得不到正常结果,熔断是最好的选择;每一次调用,在超时结束前,服务调用方,即【商品列表服务】会一直占用线程和内存资源,所以熔断可以避免资源被长时间占用,保护自己。
B 选项: 【商品列表服务】熔断对【广告服务】的调用,返回结果肯定是错误的,为了提升用户体验,可以返回默认的广告页面,做降级处理;这种情况就是由【熔断】触发的【降级】。
C 选项: 根据 A 选项的分析,如果【商品列表服务】没有熔断处理,则自身资源将持续被占用;随着访问增多,资源占用会加剧,直至【商品列表服务】没有处理能力; 这就是由【广告服务】不正常导致其上游【商品列表服务】不正常;同样的道理,【商品列表服务】的不正常会导致其上游的服务不正常,并形成扩散效应,最终很可能导致整个系统的雪崩。
D 选项: 降级与熔断不是强绑定关系,降级可以由【熔断】触发,也可以在【异常】、【超时】、【错误】等情况发生时进行触发。

答案
ABC
相关文章:
架构师面试(六):熔断和降级
问题 在千万日活的电商系统中,商品列表页服务通过 RPC 调用广告服务;经过统计发现,在最近10秒的时间里,商品列表页服务在对广告服务的调用中有 98% 的调用是超时的; 针对这个场景,下面哪几项的说法是正确的…...
使用 DeepSeek 生成流程图、甘特图与思维导图:结合 Typora 和 XMind 的高效工作流
在现代工作与学习中,可视化工具如流程图、甘特图和思维导图能够极大地提升信息整理与表达的效率。本文将详细介绍如何使用 DeepSeek 生成 Mermaid 文本,结合 Typora 快速生成流程图和甘特图,并通过 Markdown 格式生成思维导图,最终…...
粘贴到Word里的图片显示不全
粘贴到Word里的图片显示不全,可从Word设置、图片本身、软件与系统等方面着手解决,具体方法如下: Word软件设置 经实践发现,图片在word行距的行距出现问题,可以按照如下调整行距进行处理 修改段落行距: 选…...
【C语言】结构体内存对齐问题
1.结构体内存对齐 我们已经基本掌握了结构体的使用了。那我们现在必须得知道结构体在内存中是如何存储的?内存是如何分配的?所以我们得知道如何计算结构体的大小?这就引出了我们今天所要探讨的内容:结构体内存对齐。 1.1 对齐规…...
【蓝桥杯单片机】第十三届省赛第二场
一、真题 二、模块构建 1.编写初始化函数(init.c) void Cls_Peripheral(void); 关闭led led对应的锁存器由Y4C控制关闭蜂鸣器和继电器 2.编写LED函数(led.c) void Led_Disp(unsigned char ucLed); 将ucLed取反的值赋给P0 开启锁存器 关闭锁存…...
类与对象(5)
上一章是类与对象(4)-CSDN博客 深入了构造函数和静态成员,大概讲解了类型转换 最后一章最后一章 友元 在 C 中,友元提供了一种突破类的访问控制(封装)的方式。通过友元,外部的函数或类可以访…...
AI知识架构之数据采集
数据采集 数据格式: 结构化数据:以固定格式和结构存储,如数据库中的表以及 Excel 表格,易于查询和分析。半结构化数据:有一定结构但不如结构化数据严格,XML 常用于数据交换,JSON 在 Web 应用中广泛用于数据传输和存储。非结构化数据:无预定义结构,文本、图像、音频和视…...
细说STM32F407单片机2个ADC使用DMA同步采集各自的1个输入通道的方法
目录 一、示例说明 二、工程配置 1、RCC、DEBUG、CodeGenerator 2、USART6 3、TIM3 (1)Mode (2)参数设置 (3) TRGO (4)ADC1_IN0 1)ADCs_Common_Settings 2&a…...
C# 将非托管Dll嵌入exe中(一种实现方法)
一、环境准备 电脑系统:Windows 10 专业版 20H2 IDE:Microsoft Visual Studio Professional 2022 (64 位) - Current 版本 17.11.4 其他: 二、测试目的 将基于C++创建DLL库,封装到C#生成的exe中。 一般C++创建的库,在C#中使用,都是采用DllImport导入的,且要求库处…...
完美解决:.vmx 配置文件是由 VMware 产品创建,但该产品与此版 VMware Workstation 不兼容
参考文章:该产品与此版 VMware Workstation 不兼容,因此无法使用 问题描述 当尝试使用 VMware Workstation 打开别人的虚拟机时,可能会遇到以下报错: 此问题常见于以下场景: 从其他 VMware 版本(如 ESX…...
使用大语言模型对接OA系统,实现会议室预定功能
随着人工智能技术的不断进步,越来越多的企业开始借助 AI 助手来提高工作效率,尤其是在日常事务的自动化处理中。比如,在许多公司里,会议室的预定是一个常见且频繁的需求,通常需要员工手动检查空闲时间并做出选择。而通…...
Ryu控制器:L2交换功能实现案例
基于 Ryu控制器 在 VM1--OVS--VM2 的简单拓扑中实现流量自动下发(流表动态安装)的完整案例。通过该案例,当VM1与VM2首次通信时,Ryu控制器会动态学习路径并下发流表,后续流量将直接由交换机转发,无需控制器介…...
动手学深度学习2025.2.23-预备知识之-线性代数
3.线性代数 (1)向量维数和张量维数的区别: (2)普通矩阵乘法: 要求左矩阵的列数等于右矩阵的行数 import torch # 创建两个矩阵 A torch.tensor([[1, 2], [3, 4]], dtypetorch.float32) B torch.tensor([[5, 6], [7, 8]], d…...
登录-07.JWT令牌-登录后下发令牌
一.思路 我们首先完成令牌生成。 在响应数据这一块 该响应数据是一个标准的Result结构,其中"data"的值就是一个JWT令牌。因此我们只需要将生成的JWT令牌封装在Result当中然后返回给前端即可。 备注是给前端看的,不用管。以后我们做校验时&…...
机器学习实战(7):聚类算法——发现数据中的隐藏模式
第7集:聚类算法——发现数据中的隐藏模式 在机器学习中,聚类(Clustering) 是一种无监督学习方法,用于发现数据中的隐藏模式或分组。与分类任务不同,聚类不需要标签,而是根据数据的相似性将其划…...
【数据序列化协议】Protocol Buffers
一、为什么需要序列化? 数据跨平台/语言交互: 不同编程语言(如 Java、Python、Go)的数据结构不兼容,序列化提供统一的数据表示。例如:Java 的 HashMap 和 Python 的 dict 需转换为通用格式(如 …...
基于 Python 的电影市场预测分析系统设计与实现(源码 + 文档)
大家好,今天要和大家聊的是一款基于 Python 的“电影市场预测分析”系统的设计与实现。项目源码以及部署相关事宜请联系我,文末附上联系方式。 项目简介 基于 Python 的“电影市场预测分析”系统主要面向以下用户角色:电影制片方、电影发行…...
计算机三级网络技术知识汇总【6】
第六章 交换机及其配置 1. 交换机基础 1.1 基本概念 局域网交换机是一种基于 MAC 地址识别,完成转发数据帧功能的一种网络连接设备。 工作在数据链路层,根据进入端口数据帧中的 MAC 地址进行数据帧的过滤、转发(也是交换机的工作原理&…...
2025教育与科研领域实战全解析:DeepSeek赋能细分场景深度指南(附全流程案例与资源)
🚀 2025教育与科研领域实战全解析:DeepSeek赋能细分场景深度指南(附全流程案例与资源)🚀 📚 目录 DeepSeek在教育与科研中的核心价值教学场景应用:从备课到课堂管理的全流程革新科研场景应用:从数据分析到论文写作的智能跃迁师生协同创新:AI赋能的个性化学习与科研…...
Linux 命令大全完整版(10)
4. 压缩与解压缩命令 gzip(gnu zip) 功能说明:压缩文件。语 法:gzip [-acdfhlLnNqrtvV][-S <压缩字尾字符串>][-<压缩效率>][–best/fast][文件…] 或 gzip [-acdfhlLnNqrtvV][-S <压缩字尾字符串>][-<压缩效率>][–best/f…...
PLC交通灯控制:博途V15与S7-1200的‘比较指令‘编程与触摸屏调试实践
PLC交通灯控制,博途V15,S7-1200 使用比较指令,程序完整,触摸屏调试正常,触摸屏上有倒计时显示功能。 有两份对应实训报告(设计说明书),包括每段程序原理解释,触摸屏设置过程…...
成本杀手!用两个三极管搞定MOS管驱动,从电平转换到‘假推挽’避坑全攻略
低成本MOS驱动设计实战:三极管方案从电平转换到“伪推挽”避坑指南 在硬件设计中,MOS管驱动电路的成本和可靠性常常成为工程师的两难选择。商用驱动芯片虽性能稳定但价格昂贵,而三极管搭建的方案成本低廉却暗藏玄机。本文将带你深入两个三极管…...
032_A27_火火兔学前英语_中字幕_零基础_3岁+资源介绍与网盘获取
A27 火火兔学前英语 中字幕 零基础 3岁资源介绍与网盘获取 对于很多家长来说,给孩子挑选英语启蒙资料时,最看重的往往是“是否适合零基础”“内容是否容易理解”“孩子愿不愿意看”。A27 火火兔学前英语 中字幕 零基础 3岁 这类资料,从名称来…...
终极指南:如何用EverythingToolbar实现Windows文件搜索效率翻倍 [特殊字符]
终极指南:如何用EverythingToolbar实现Windows文件搜索效率翻倍 🚀 【免费下载链接】EverythingToolbar Everything integration for the Windows taskbar. 项目地址: https://gitcode.com/gh_mirrors/eve/EverythingToolbar 你是否厌倦了在Windo…...
用Python和NumPy动手实现8种DST变换:从公式到可视化基图像
用Python和NumPy动手实现8种DST变换:从公式到可视化基图像 在信号处理领域,离散正弦变换(DST)是一组与离散余弦变换(DCT)齐名的重要工具。不同于DCT的对称延拓特性,DST通过反对称延拓方式处理信…...
Windows 10/11 下用 Anaconda 搞定 PyTorch 1.2.0 + CUDA 10.0 环境(保姆级避坑指南)
Windows 深度学习环境搭建实战:Anaconda PyTorch 1.2.0 全流程解析 刚接触深度学习的开发者往往会在环境配置阶段遇到各种"玄学问题"——明明按照教程操作却报错不断,显卡驱动不匹配、库版本冲突、下载速度慢等问题层出不穷。本文将用最接地…...
Simulink项目复用实战:一个模型适配多个客户需求,全靠可变子系统
Simulink项目复用实战:一个模型适配多个客户需求,全靠可变子系统 在工业自动化、汽车电子和航空航天等领域,系统工程师常常面临一个棘手问题:如何用同一套控制模型满足不同客户的定制化需求?传统做法是为每个客户单独维…...
这篇带你彻底拿捏Redis数据结构 !
Redis 为什么那么快?除了它是内存数据库,使得所有的操作都在内存上进行之外,还有一个重要因素,它实现的数据结构,使得我们对数据进行增删查改操作时,Redis 能高效的处理。因此,这次我们就来好好…...
BLE蓝牙模块型号,BLE蓝牙串口芯片应用
一、BLE蓝牙模块概述 传统串口设备升级无线通信功能时,往往需要重写底层驱动或修改上位机软件。而采用虚拟化串口技术的BLE蓝牙模块,通过将蓝牙连接模拟为本地COM口,使原有基于串口的上位机软件无需任何改动即可收发数据。这种“无感替换”能…...
浙江大学毕业论文LaTeX模板:3步告别格式烦恼,专注学术研究
浙江大学毕业论文LaTeX模板:3步告别格式烦恼,专注学术研究 【免费下载链接】zjuthesis Zhejiang University Graduation Thesis LaTeX Template 项目地址: https://gitcode.com/gh_mirrors/zj/zjuthesis 还在为毕业论文的格式要求头疼吗ÿ…...
