Spring Cloud——Circuit Breaker上篇

Spring Cloud——Circuit Breaker上篇

  • 一、分布式系统面临的问题
    • 1.服务雪崩
    • 2.禁止服务雪崩故障
  • 二、Circuit Breaker
  • 三、resilience4j——服务熔断和降级
    • 1.理论知识
    • 2.常用配置
    • 3.案例实战
      • (1)COUNT_BASED(计数的滑动窗口)
      • (2)TIME_BASED(时间的滑动窗口)
  • 四、参考

一、分布式系统面临的问题

  • 复杂分布式体系结构中的应用程序有数十个依赖关系,每个依赖关系在某些时候将不可避免地失败。

1.服务雪崩

  • 多个微服务之间调用的时候,假设微服务A调用微服务B和微服务C,微服务B和微服务C又调用其他的微服务,这就是所谓的“扇出”。如果扇出的链路上某个微服务的调用响应时间过长或者不可用,对微服务A的调用就会占用越来越多的系统资源,进而引起系统崩溃,所谓的“雪崩效应”。
  • 对于高流量的应用来说,单一的后端依赖可能会导致所有服务器上的所有资源都在几秒钟内饱和。比失败更糟糕的是,这些应用程序还可能导致服务之间的延迟增加,备份队列,线程和其他系统资源紧张,导致整个系统发生更多的级联故障。这些都表示需要对故障和延迟进行隔离和管理,以便单个依赖关系的失败,不能取消整个应用程序或系统。
  • 通常当你发现一个模块下的某个实例失败后,这时候这个模块依然还会接收流量,然后这个有问题的模块还调用了其他的模块,这样就会发生级联故障,或者叫雪崩。

2.禁止服务雪崩故障

  • 有问题的节点,快速熔断(快速返回失败处理或者返回默认兜底数据【服务降级】)。
  • “断路器”本身是一种开关装置,当某个服务单元发生故障之后,通过断路器的故障监控(类似熔断保险丝),向调用方返回一个符合预期的、可处理的备选响应(FallBack),而不是长时间的等待或者抛出异常调用方法处理的异常,这样就保证了服务调用方的线程不会被长时间、不必要地占用,从而避免了故障在分布式系统中的蔓延,乃至雪崩。

二、Circuit Breaker

在这里插入图片描述

  • Circuit Breaker 只是一套规范和接口,落地实现者是 Resilience4j(resilience For Java)Spring Retry

三、resilience4j——服务熔断和降级

1.理论知识

  • Circuit Breaker 有三个普通状态:关闭(CLOSED)开启(OPEN)半开(HALF_OPEN),还有两个特殊状态:禁用(DISABLED)强制开启(FORCED_OPEN)
    在这里插入图片描述
    • 当断路器 CLOSED 时,所有的请求都会通过断路器。
    • 如果失败率超过设定的阈值,断路器 CLOSED ---> OPEN,这时所有的请求都会被拒绝。
    • 当经过一段时间后,断路器OPEN ---> HALF_OPEN,这时仅有一定数量的请求会被放入,并重新计算失败率。
    • 如果失败率仍超过阈值,则断路器 HALF_OPEN ---> OPEN,如果失败率低于阈值,则断路器 HALF_OPEN ---> CLOSED
  • 断路器使用滑动窗口来存储和统计调用的结果。
    • 基于调用数量的滑动窗口:基于访问数量的滑动窗口统计了最近 N 次调用的返回结果。
    • 基于时间的滑动窗口:基于时间的滑动窗口统计了最近 N 秒的调用返回结果。
  • 除此之外,断路器还会有两种特殊状态:DISABLE(始终允许访问)FOCRED_OPEN(始终拒绝访问)
    • 这两个状态不会生成熔断器事件(除状态转换外),并且不会记录请求的成功或失败。
    • 退出这两个状态的唯一方法就是触发状态转换或者重置断路器

2.常用配置

配置属性默认值描述
slidingWindowTypeCOUNT_BASED配置滑动窗口的类型,当断路器关闭时,将调用的结果记录在滑动窗口中。滑动窗口的类型可以是count-based或time-based。如果滑动窗口类型是COUNT_BASED,将会统计记录最近slidingWindowSize次调用的结果。如果是TIME_BASED,将会统计记录最近slidingWindowSize秒的调用结果。
slidingWindowSize100配置滑动窗口的大小。
failureRateThreshold50以百分比配置失败率阈值。当失败率等于或大于阈值时,断路器状态从关闭变为开启,并进行服务降级。
slowCallDurationThreshold6000[ms]配置调用时间的阈值,高于该阈值的呼叫视为慢调用,并增加慢调用比例。
slowCallRateThreshold100以百分比的方式配置,断路器把调用时间大于slowCallDurationThreshold的调用视为慢调用,当慢调用比例大于等于阈值时,断路器开启,并进行服务降级。
permittedNumberOfCallsInHalfOpenState10断路器在半开状态下允许通过的调用次数。
minimumNumberOfCalls100断路器计算失败率或慢调用率之前所需的最小调用数(每个滑动窗口周期)。例如,如果minimumNumberOfCalls为10,则必须至少记录10个调用,然后才能计算失败率。如果只记录了9次调用,即使所有9次调用都失败,断路器也不会开启。
waitDurationInOpenState6000[ms]断路器从开启过渡到半开应等待的时间。

3.案例实战

  • 具体案例:
    • 6 次访问中当执行方法的失败率达到 50% 时 CircuitBreaker 将进入开启 OPEN 状态(保险丝跳闸断电),拒绝所有请求。
    • 等待 5 秒后,CircuitBreaker 将自动从开启 OPEN 状态过渡到半开 HALF_OPEN 状态,允许一些请求通过以测试服务是否恢复正常。
    • 如还是异常 CircuitBreaker 将重新进入开启 OPEN 状态;如正常将进入关闭 CLOSE 关闭状态恢复正常处理请求。
      在这里插入图片描述

(1)COUNT_BASED(计数的滑动窗口)

  • 第一步,在调用服务方引入 Circuit Breaker 相关的依赖
    <!--resilience4j-circuitbreaker-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-circuitbreaker-resilience4j</artifactId>
    </dependency>
    <!-- 由于断路保护等需要AOP实现,所以必须导入AOP包 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-aop</artifactId>
    </dependency>
    
  • 第二步,在OpenFeign中开启circuitbreaker
    spring:
      cloud:
        openfeign:
          # 开启 circuitbreaker 和 分组激活
          circuitbreaker:
            enabled: true
            # 没开分组永远不用分组的配置。精确优先、分组次之(开了分组)、默认最后
            group:
              enabled: true
    
  • 第三步,配置resilience4j相关的配置
    # 服务器的熔断降级配置
    resilience4j:
      circuitbreaker:
        configs:
          default:
          	# 设置 50% 的失败率,超过失败请求百分比 CircuitBreaker 变为 OPEN 状态。
            failure-rate-threshold: 50 
            # 滑动窗口类型
            sliding-window-type: COUNT_BASED
            # 滑动窗口的大小, 配置 COUNT_BASED 表示 6 个请求,配置 TIME_BASED 表示 6 秒。
            sliding-window-size: 6
            # 断路器计算失败率或慢调用率之前所需的最小样本(每个滑动窗口周期)。如果 minimumNumberOfCalls 为 10, 则必须最少记录 10 个样本,然后才能计算失败率。如果只记录了9次调用,即使所有9次调用都失败,断路器也不会开启。
            minimum-number-of-calls: 6
            # 是否启用自动从 OPEN ---> HALF_OPEN, 默认值就为 TRUE
            automatic-transition-from-open-to-half-open-enabled: true  
            # 从 OPEN 到 HALF_OPEN状态需要等待的时间
            wait-duration-in-open-state:
              seconds: 1
            # 半开状态允许的最大请求值为 10.
            permitted-number-of-calls-in-half-open-state: 2
            # 记录的异常类型
            record-exceptions:
              - java.lang.Exception
        # 以上的配置适用于那个微服务
        instances:
          cloud-payment-service:
            base-config: default
    
  • 第四步,编写Controller
    @RestController
    @RequestMapping("/circuit")
    public class CircuitController {
        @Resource
        private PayCircuitFeignAPI payCircuitFeignAPI;
    
        @GetMapping("/order/{id}")
        @CircuitBreaker(name = "cloud-payment-service", fallbackMethod = "myCircuitFallback")
        public String myCircuit(@PathVariable("id") Integer id) {
            return payCircuitFeignAPI.myCircuit(id);
        }
    
        /**
         * myCircuitFallback就是服务降级后的兜底处理方法
         */
        public String myCircuitFallback(Integer id, Throwable t) {
            // 这里是容错处理逻辑,返回备用结果
            return "myCircuitFallback,系统繁忙,请稍后再试-----/(ㄒoㄒ)/~~";
        }
    }
    

(2)TIME_BASED(时间的滑动窗口)

  • 只需要将上面基于次数的滑动窗口中关于resilience4j相关的配置修改为如下
    # 服务器的熔断降级配置
    resilience4j:
      timelimiter:
        configs:
          default:
          	# 神坑的位置,timelimiter 默认限制远程 1s,超过 1s 就超时异常,配置了降级,就直接走降级逻辑了
            timeout-duration:
              seconds: 20
      circuitbreaker:
        configs:
          default:
          	#设置 50% 的失败率,超过失败请求百分比 CircuitBreaker 变为 OPEN 状态。
            failure-rate-threshold: 50
            # 滑动窗口类型 
            sliding-window-type: TiME_BASED
            # 慢调用时间阈值,高于这个阈值的视为慢调用并增加慢调用比例。
            slow-call-duration-threshold:
              seconds: 2
            #慢调用百分比峰值,断路器把调用时间大于 slow-call-duration-threshold,视为慢调用,当慢调用比例高于这个的时候进入到 OPEN。 
            slow-call-rate-threshold: 30
            # 滑动窗口的大小, 配置 COUNT_BASED 表示 2 个请求,配置 TIME_BASED 表示 2 秒。 
            sliding-window-size: 2 
            # 断路器计算失败率或慢调用率之前所需的最小样本(每个滑动窗口周期)。如果 minimumNumberOfCalls 为 10, 则必须最少记录 10 个样本,然后才能计算失败率。如果只记录了9次调用,即使所有9次调用都失败,断路器也不会开启。
            minimum-number-of-calls: 2 
            automatic-transition-from-open-to-half-open-enabled: true  # 是否启用自动从 OPEN ---> HALF_OPEN, 默认值就为 TRUE
            # 从 OPEN 到 HALF_OPEN状态需要等待的时间
            wait-duration-in-open-state:
              seconds: 10  
            # 半开状态允许的最大请求值为
            permitted-number-of-calls-in-half-open-state: 2 
            # 记录的异常类型
            record-exceptions:
              - java.lang.Exception
        # 以上的配置适用于那个微服务
        instances:
          cloud-payment-service:
            base-config: default
    

四、参考

[1]. Spring Cloud Circuit Breaker
[2]. resilience4j 官网
[3]. resilience4j 中文参考手册


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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring Cloud——OpenFeign

Spring Cloud——OpenFeign 一、OpenFeign能干嘛二、OpenFeign的基本使用三、Feign的高级特性1.OpenFeign超时控制2.OpenFeign重试机制3.OpenFeign之性能优化HttpClient54.OpenFeign请求和响应压缩5.OpenFeign之Feign日志打印 四、参考 OpenFeign是一个声明式的Web服务客户端。…

Android --- 消息机制与异步任务

在Android中&#xff0c;只有在UIThread(主线程)中才能直接更新界面&#xff0c; 在Android中&#xff0c;长时间的工作联网都需要在workThread(分线程)中执行 在分线程中获取服务器数据后&#xff0c;需要立即到主线程中去更新UI来显示数据&#xff0c; 所以&#xff0c;如…

程序员的五大方法论

前言&#xff1a; 最近看了一篇总结程序员学习&#xff0c;晋升方法的文章&#xff0c;颇有感想&#xff0c;决定分享给大家&#xff0c;原文地址&#xff1a;给程序员的5条学习方法论 (qq.com)https://mp.weixin.qq.com/s/xVFlF9qTf9c74Emmdm0DqA 在繁忙的工作中&#xff0c;持…

如何在postman上提交文件格式的数据

如何在postman上提交文件格式的数据 今天在写一个文件上传的功能接口时&#xff0c;想用postman进行提交&#xff0c;花了些时间才找到在postman提交文件格式的数据。记录一下吧&#xff01; 1.打开postman&#xff0c;选择POST提交方式&#xff0c;然后在Params那一行的Head…

代码随想录算法训练营DAY45|C++动态规划Part7|70.爬楼梯(进阶版)、322. 零钱兑换、279.完全平方数

文章目录 70.爬楼梯&#xff08;进阶版&#xff09;322. 零钱兑换思路CPP代码 279.完全平方数思路CPP代码 70.爬楼梯&#xff08;进阶版&#xff09; 卡码网&#xff1a;57. 爬楼梯 文章讲解&#xff1a;70.爬楼梯(进阶版) 322. 零钱兑换 力扣题目链接 文章讲解&#xff1a;322…

安装英伟达nvidia p4计算卡驱动@FreeBSD14

FreeBSD也能跑cuda AI训练拉&#xff01; 在FreeBSD安装好pytorch和飞桨cpu版本后&#xff0c;尝试安装英伟达nvidia p4计算卡驱动。毕竟全靠cpu速度太慢了&#xff0c;还是GPU快啊&#xff01;在磕磕绊绊几天后&#xff0c;终于成功成功安装好nvidia p4的cuda驱动&#xff0c…

从零开始:Django项目的创建与配置指南

title: 从零开始&#xff1a;Django项目的创建与配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 后端开发 tags: DjangoWebDevPythonORMSecurityDeploymentOptimization Django简介&#xff1a; Django是一个开源的高级Python Web框架&#xff…

The Role of Subgroup Separability in Group-Fair Medical Image Classification

文章目录 The Role of Subgroup Separability in Group-Fair Medical Image Classification摘要方法实验结果 The Role of Subgroup Separability in Group-Fair Medical Image Classification 摘要 研究人员调查了深度分类器在性能上的差异。他们发现&#xff0c;分类器将个…

PHP源码_最新在线工具箱网站系统源码

项目运行截图 源码贡献 https://githubs.xyz/boot?app41 部分数据库表 SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS 0;-- ---------------------------- -- Table structure for toolbox_category -- ---------------------------- DROP TABLE IF EXISTS toolbox_category…

【网络原理】HTTP 协议的基本格式和 fiddler 抓包工具的用法

系列文章目录 【网络通信基础】网络中的常见基本概念 【网络编程】网络编程中的基本概念及Java实现UDP、TCP客户端服务器程序&#xff08;万字博文&#xff09; 【网络原理】UDP协议的报文结构 及 校验和字段的错误检测机制&#xff08;CRC算法、MD5算法&#xff09; 【网络…

下载安装 VisualVM

1、下载安装 VisualVM 第1步&#xff1a;下载地址&#xff1a;https://visualvm.github.io/ 第2步&#xff1a;解压到制定位置 第3步&#xff1a;指定jdk路径 下载完成后&#xff0c;在etc文件夹下找到visualvm.conf文件&#xff0c;设置jdk路径visualvm_jdkhome"D:\ITS…

ICode国际青少年编程竞赛- Python-1级训练场-路线规划

ICode国际青少年编程竞赛- Python-1级训练场-路线规划 1、 Dev.step(3) Dev.turnLeft() Dev.step(4)2、 Dev.step(3) Dev.turnLeft() Dev.step(3) Dev.step(-6)3、 Dev.step(-2) Dev.step(4) Dev.turnLeft() Dev.step(3)4、 Dev.step(2) Spaceship.step(2) Dev.step(3)5、…

ElasticSearch教程入门到精通——第一部分(基于ELK技术栈elasticsearch 8.x新特性)

ElasticSearch教程入门到精通——第一部分&#xff08;基于ELK技术栈elasticsearch 8.x新特性&#xff09; 1. ElasticSearch安装&#xff08;略&#xff09;2. ElasticSearch基础功能2.1 索引操作2.1.1 创建索引2.1.2 Head 索引2.1.3 查询索引2.1.3.1 查询单独索引2.1.3.2 查询…

【MATLAB】GUI初步设计

MATLAB界面设计 前言一、基本步骤1.1 创建GUI文件1.2 界面设计 总结 前言 为了完成图像处理的作业&#xff0c;简直就是生活不易啊 找到一个很棒的教学视频 基于MATLAB的GUI界面设计流程讲解 一、基本步骤 1.1 创建GUI文件 由于在写博文之前我已经创建好文件了&#xff0c;…

邊緣智能2024—AI開發者峰會(5月9日)數碼港即將啟幕

隨著 AI &#xff08;人工智能&#xff09;技術的飛速發展&#xff0c;我們正迎來邊緣計算智能化與分布式AI深度融合的新時代&#xff0c;共同演繹分布式智能創新應用的壯麗篇章。"邊緣智能2024 - AI開發者峰會"將聚焦於這一前沿領域&#xff0c;探討如何通過邊緣計算…

中国发布首个汽车大模型标准

&#x1f989; AI新闻 &#x1f680; 中国发布首个汽车大模型标准 摘要&#xff1a;中国信息通信研究院于4月28日发布了国内首个汽车大模型标准&#xff0c;标志着汽车行业正式迈向“人工智能&#xff0b;”时代。该标准包含三个核心能力域&#xff1a;场景丰富度、能力支持度…

Pytorch学习笔记——环境配置安装

1、下载和配置环境 Anacodna必备&#xff08;工具包里面都包含的有&#xff0c;集成与运用科学分析的软件&#xff0c;比较方便&#xff09; 点击这个网页:Download Now | Anacondahttps://www.anaconda.com/download/success 按照教程安装&#xff08;教程可以自己在网上搜…

XY_RE复现(五)

一&#xff0c;给阿姨倒一杯卡布奇诺 是一道魔改TEA加密 给出了一些初始化&#xff0c;然后输入的flag拆分&#xff0c;两两一组&#xff0c;通过for循环放入encrypt加密函数 #include <stdio.h> #define uint32_t unsigned intvoid decrypt(uint32_t *v, uint32_t *ke…

拆单算法交易(Algorithmic Trading)

TWAP TWAP交易时间加权平均价格Time Weighted Average Price 模型&#xff0c;是把一个母单的数量平均地分配到一个交易时段上。该模型将交易时间进行均匀分割&#xff0c;并在每个分割节点上将拆分的订单进行提交。例如&#xff0c;可以将某个交易日的交易时间平均分为N 段&am…

守护数据安全: 零信任视角下的勒索病毒防范之道

前言 就在近日&#xff0c;鸿海集团旗下半导体设备大厂——京鼎精密科技股份有限公司&#xff08;以下简称“京鼎”&#xff09;遭到了黑客的入侵。黑客在京鼎官网公布信息直接威胁京鼎客户与员工&#xff0c;如果京鼎不支付赎金&#xff0c;客户资料将会被公开&#xff0c;员…