熔断,降级,限流区别

2023-11-10

熔断、限流、降级都是保持系统稳定运行的策略,但针对的场景有所不同。

熔断
服务熔断的作用类似于我们家用的保险丝,当某服务出现不可用或响应超时的情况时,为了防止整个系统出现雪崩,暂时停止对该服务的调用。

上面的解释中有两个很关键的词,一个是暂时,一个是停止。

停止是说,当前服务一旦对下游服务进行熔断,当请求到达时,当前服务不再对下游服务进行调用,而是使用设定好的策略(如构建默认值)直接返回。

暂时是说,熔断后,并不会一直不再调用下游服务,而是以一定的策略(如每分钟调用 10 次,若均返回成功,则增大调用量)试探调用下游服务,当下游服务恢复可用时,自动停止熔断。

如上图,当 ServiceD 不可用时,ServiceB 应对 ServiceD 进行熔断。

开源的熔断器,如:Hystrix

限流
限流是指上游服务对本服务请求 QPS 超过阙值时,通过一定的策略(如延迟处理、拒绝处理)对上游服务的请求量进行限制,以保证本服务不被压垮,从而持续提供稳定服务。常见的限流算法有滑动窗口、令牌桶、漏桶等。

如上图,当 ServiceB 对 ServiceD 请求过多时,ServiceD 可以放弃一部分请求,保证自身服务的稳定。

目前比较常用的限流算法有以下几种:

计数器固定窗口算法
计数器滑动窗口算法
漏桶算法
令牌桶算法
降级
降级是指当自身服务压力增大时,采取一些手段,增强自身服务的处理能力,以保障服务的持续可用。比如,下线非核心服务以保证核心服务的稳定、降低实时性、降低数据一致性。

常见的降级策略:

读旧
PlanB
默认值
放弃部分请求
降低质量
提高参与门槛
反向过滤
补偿
容灾
总结
措施 产生原因 针对服务
熔断 下游服务不可用 下游服务
降级 自身服务的处理能力不够 自身服务
限流 上游服务请求增多 上游服务

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

熔断,降级,限流区别 的相关文章

  • MySQL 高级篇 -- 性能分析

    文章目录 一 基础知识 1 1 数据库服务器的优化步骤 1 2 查看系统性能参数 1 3 统计 SQL 查询成本 1 4 查看 SQL 执行成本 二 mysqldumpslow 慢日志分析 2 1 相关变量 2 2 案例准备 2 3 测试
  • Mac下Fiddler的安装、配置与使用

    环境安装 Mono安装 首先 Mac下需要使用 Net编译后的程序 需要用到跨平台的方案Mono 现阶段微软已推出跨平台的方案 Net Core 不过暂时只支持控制台程序 安装程 可以从 http www mono project com
  • 第二十四课、二十五课,高级光照(blinn),Gamma矫正

    高级光照 blinn 这里主要是矫正了 视口方向和反射方向夹角太小造成的阴影轮廓现象 但是在我的项目中 只要给blinn光照的shiness乘4 基本与冯氏光照没有区别 if light blinn vec3 halfwayDir norm
  • 从零开始的Spring Security Oauth2(一)

    使用配置 1 简易的分为三个步骤 配置资源服务器 配置认证服务器 配置spring security 2 oauth2根据使用场景不同 分成了4种模式 授权码模式 authorization code 简化模式 implicit 密码模式
  • Unity的画面高质量传输( FMETP STREAM 实时画面传输案例)

    Unity中实现画面传输首先要保证在同一个局域网下 其次 用到的FMETP STREAM插件进行画面传输的时候不分Server端和Client端 下面我们看一个案例 用大屏和小屏举例 我们要实时把小屏内容传输到大屏上 首先建两个空物体Ser
  • 矩阵分析L6矩阵函数

    一 范数 1 范数与内积 内积 对两个空间进行内积运算可以得到一个实数集 范数 对一个空间可以直接进行向量 大小 的衡量 得到实数集 2 向量范数 正定性 范数为0 则每个向量必为0 3 例题 向量范数判断 4 p级范数 注意 范数 Y 若

随机推荐

  • 老猿学5G扫盲贴:R15/R16中计费架构和计费原则涉及的规范文档

    专栏 Python基础教程目录 专栏 使用PyQt开发图形界面Python应用 专栏 PyQt入门学习 老猿Python博文目录 老猿学5G博文目录 一 概述 在R16的32 240文档对应规范为3GPP TS 32 240 V16 1 0
  • [Java Web开发]Servlet学习

    目录 一 什么是Servlet 二 Servlet生命周期 三 Servlet工作过程 四 Servlet项目实战 一 什么是Servlet Servlet是SUN公司提供的一门用于开发动态web资源的技术 它是Java Web三大组件 之
  • Linux 内核蓝牙驱动移植

    实验原理 FS MP1A开发板蓝牙采用 AP6236 AP6212 WIFI蓝牙二合一芯片 蓝牙部分通过 usart3与 SoC 进行数据交互 注意 此部分内容为 AP6236 AP6212 移植过程 如果 WIFI 蓝牙是 USB 模块可
  • 技术部岗位职责——技术部经理

    一 制定工作计划 根据企业新产品开发 工艺技术改进计划制定技术部的年度 季度工作目标和工作计划 经批准后组织实施 根据产品研发与工艺技术发展需要 制定工艺试验研究计划 并组织实施 二 技术研发管理 编制本部门各项管理程序 新产品工艺技术标准
  • OpenWrt Makefile 整体分析

    分析版本 svn svn openwrt org cn openwrt branches backfire OpenWrt基本结构 target Linux 目录里面是各平台 arch 的相关代码 target linux config 文
  • oracle中存储过程 查询出多条数据的处理方法

    oracle中存储过程 查询出多条数据的处理方法 用游标处理 定义游标 cursor a is select begin open a loop fetch a into 自己定义的变量 开始操作 end loop close a end
  • Charles下载ssl证书-app端

    1 点击help 选择SSL Proxying 选择安装app端ssl证书 2 这里可以看到我们的IP 以及端口号 3 在手机端更改WiFi的代理 切换为手动代理 IP端口更改为提示的信息 注意电脑端跟移动端必须保持在同一网络下 4 这里电
  • Secure Federated Matrix Factorization学习总结

    Secure Federated Matrix Factorization学习总结 背景 传统的矩阵分解推荐系统 会泄漏用户的评分信息 特征向量 可能大家会觉得泄漏这两种信息不重要 但是通过这两种信息 恶意攻击者可以进行inference
  • 域渗透笔记-证书服务器(ADCS)安装

    什么是ADCS AD CS证书服务 SSL证书 可以部署企业根或独立根建立SSL加密通道 这是所有服务器证书 无论品牌 申请方式都可以起到的功能 唯一的价值区别在于加密强度 目前 达到128位对称加密强度的服务器证书均可以实现有保障的加密通
  • python抢淘宝的东西-Python 实现毫秒级淘宝抢购脚本的示例代码

    本篇文章主要介绍了Python 通过selenium实现毫秒级自动抢购的示例代码 通过扫码登录即可自动完成一系列操作 抢购时间精确至毫秒 可抢加购物车等待时间结算的 也可以抢聚划算的商品 博主不提供任何服务器端程序 也不提供任何收费抢购软件
  • 关于解决Uncaught SyntaxError: The requested module ‘/node_modules/.vite/deps/vue-router.js?v=569ce1cd‘ d

    1 按照官方文档我们需要引入VueRouter 但是会报错 大致翻译为 请求的模块 node modules vite deps vue router js V 569ce1cd 没有提供名为 default 的导出 因为vue底层代码 导
  • 输入一个字符串,编写函数统计该字符串中的字母、数字和其他字符的个数;

    欢迎加qq群 453398542 学习讨论 会定期分享资料课程 解答问题 输入一个字符串 编写函数统计该字符串中的字母 数字和其他字符的个数 include
  • 高通9008固件下载备份工具

    高通9008固件下载备份工具 www bbs 16rd com
  • Spring项目配置文件中RabbitMQ监听器各个参数的作用

    spring rabbitmq listener simple concurrency 设置监听器容器的并发消费者数量 默认为1 即单线程消费 spring rabbitmq listener simple max concurrency
  • MySql数据库varchar和java字符串length()长度tips

    Java 中字符串以 Unicode 方式编码的 其长度通常计算的是字符数 一个中文也算一个字符 public static void main String args String fileName 中文English 12345 中文
  • CTFshow之web5

    CTFshow web web5 考察md5绕过 web5 考察md5绕过 首先打开页面是一个页面源码 我们先来进行代码审计 看有没有可以利用的地方 重点审计这段代码
  • Bitlocker加密,与解除加密

    引文 应为C盘空间不够用了 想着用U盘从新给C盘分下区 操作时才发现我系统里的磁盘都是Bitlocker加密的 分区工具操作不了磁盘 所以就找到一下方法来解决 1 先讲一下解除加密 直接点击 设置 gt 隐私和安全性 gt 设备加密 gt
  • Android PackageManagerService源码分析和APK安装原理详解

    前些天发现了一个蛮有意思的人工智能学习网站 8个字形容一下 通俗易懂 风趣幽默 感觉非常有意思 忍不住分享一下给大家 点击跳转到教程 一 PackageManagerService简称PMS PackageManagerService是An
  • Unity Physics.OverlapSphere实现冲击波

    知识点1 球形射线检测 根据 层级Layer 和 半径值球形范围 内 过滤获得 Collider数组 用途 冲击波 对范围内游戏对象造成伤害 Physics OverlapSphere gameObject transform positi
  • 熔断,降级,限流区别

    熔断 限流 降级都是保持系统稳定运行的策略 但针对的场景有所不同 熔断 服务熔断的作用类似于我们家用的保险丝 当某服务出现不可用或响应超时的情况时 为了防止整个系统出现雪崩 暂时停止对该服务的调用 上面的解释中有两个很关键的词 一个是暂时