SpringCloudAlibaba中使用Sentinel实现熔断降级之熔断策略详解_熔断保护策略-程序员宅基地

技术标签: spring  微服务  java  微服务架构  

场景

SpringCloudAlibaba中使用Sentinel实现流量控制以及流控规则详解:

SpringCloudAlibaba中使用Sentinel实现流量控制以及流控规则详解_霸道流氓气质的博客-程序员宅基地

在上面使用Sentinel实现流量控制的基础上,怎样进行熔断降级。

官网文档说明

https://github.com/alibaba/Sentinel/wiki/%E7%86%94%E6%96%AD%E9%99%8D%E7%BA%A7

除了流量控制以外,对调用链路中不稳定的资源进行熔断降级也是保障高可用的重要措施之一。一个服务常常会调用别的模块,可能是另外的一个远程服务、数据库,或者第三方 API 等。例如,支付的时候,可能需要远程调用银联提供的 API;查询某个商品的价格,可能需要进行数据库查询。然而,这个被依赖服务的稳定性是不能保证的。如果依赖的服务出现了不稳定的情况,请求的响应时间变长,那么调用服务的方法的响应时间也会变长,线程会产生堆积,最终可能耗尽业务自身的线程池,服务本身也变得不可用。

现代微服务架构都是分布式的,由非常多的服务组成。不同服务之间相互调用,组成复杂的调用链路。以上的问题在链路调用中会产生放大的效果。复杂链路上的某一环不稳定,就可能会层层级联,最终导致整个链路都不可用。因此我们需要对不稳定的弱依赖服务调用进行熔断降级,暂时切断不稳定调用,避免局部不稳定因素导致整体的雪崩。熔断降级作为保护自身的手段,通常在客户端(调用端)进行配置。

注意

注意官方版本说明,此时的版本为1.8.4

 

降级策略

1、慢调用比例 (SLOW_REQUEST_RATIO):

选择以慢调用比例作为阈值,需要设置允许的慢调用 RT(即最大的响应时间),请求的响应时间大于该值则统计为慢调用。当单位统计时长(statIntervalMs)内请求数目大于设置的最小请求数目,并且慢调用的比例大于阈值,则接下来的熔断时长内请求会自动被熔断。经过熔断时长后熔断器会进入探测恢复状态(HALF-OPEN 状态),若接下来的一个请求响应时间小于设置的慢调用 RT 则结束熔断,若大于设置的慢调用 RT 则会再次被熔断。


2、异常比例 (ERROR_RATIO):

当单位统计时长(statIntervalMs)内请求数目大于设置的最小请求数目,并且异常的比例大于阈值,则接下来的熔断时长内请求会自动被熔断。经过熔断时长后熔断器会进入探测恢复状态(HALF-OPEN 状态),若接下来的一个请求成功完成(没有错误)则结束熔断,否则会再次被熔断。异常比率的阈值范围是 [0.0, 1.0],代表 0% - 100%。


3、异常数 (ERROR_COUNT):

当单位统计时长内的异常数目超过阈值之后会自动进行熔断。经过熔断时长后熔断器会进入探测恢复状态(HALF-OPEN 状态),若接下来的一个请求成功完成(没有错误)则结束熔断,否则会再次被熔断。

参考Hystrix实现熔断降级

SpringCloud中集成Hystrix实现服务降级(从实例入手):

SpringCloud中集成Hystrix实现服务降级(从实例入手)_霸道流氓气质的博客-程序员宅基地

SpringCloud中集成Hystrix实现熔断(从实例入手):

SpringCloud中集成Hystrix实现熔断(从实例入手)_霸道流氓气质的博客-程序员宅基地

注:

博客:
霸道流氓气质的博客_程序员宅基地-C#,架构之路,SpringBoot领域博主
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。

实现

1、熔断策略-慢调用比例

参考上面集成Sentinel实现流量控制的基础上,添加测试接口

    @GetMapping("/testD")
    public String testD()
    {
        try { TimeUnit.SECONDS.sleep(1); } catch (InterruptedException e) { e.printStackTrace(); }
        log.info("testD 测试RT");
        return "------testD";
    }

使接口等待一秒之后返回。

然后新建熔断规则,配置参数如下

 

熔断降级规则说明

熔断降级规则(DegradeRule)包含下面几个重要的属性:

Field 说明 默认值
resource 资源名,即规则的作用对象 
grade 熔断策略,支持慢调用比例/异常比例/异常数策略 慢调用比例
count 慢调用比例模式下为慢调用临界 RT(超出该值计为慢调用);异常比例/异常数模式下为对应的阈值 
timeWindow 熔断时长,单位为 s 
minRequestAmount 熔断触发的最小请求数,请求数小于该值时即使异常比率超出阈值也不会熔断(1.7.0 引入) 5
statIntervalMs 统计时长(单位为 ms),如 60*1000 代表分钟级(1.8.0 引入) 1000 ms
slowRatioThreshold 慢调用比例阈值,仅慢调用比例模式有效(1.8.0 引入) 
熔断器事件监听

具体可以参考其官网

 

所以这里配置的规则的含义是:

如果一秒内持续进入大于等于5个请求,并且请求响应的时间大于200毫秒的请求即为慢调用,当慢调用的比例大于0.2时就会触发降级,直到3秒后新的请求响应时间小于200毫秒才结束熔断。

使用jmeter进行压力模拟测试可以参考如下

Jmeter进行http接口压力测试:

Jmeter进行http接口压力测试_霸道流氓气质的博客-程序员宅基地

这里模拟10个线程一秒一次的发起请求并持续进行。

 

启动jmeter压力测试之后再访问testD接口

 

2、熔断策略-异常比例

修改上面的testD接口,让其出现异常

    @GetMapping("/testD")
    public String testD()
    {
        log.info("testD 异常比例");
        int age = 10/0;
        return "------testD";
    }

此时直接访问该接口,没有触发熔断降级之前会直接报错

 

修改上面的熔断策略如下

 

此规则的含义为:

如果1秒内持续进入大于等于5个请求,并且请求中异常的比例大于0.2,则触发降级,降级时间持续3秒,3秒后,如果不再异常,才结束熔断。

效果

 

3、熔断降级策略-异常数

修改上面的规则如下

 

上面配置的含义是:

如果1秒内持续进入大于等于5个请求,并且请求发生异常数超过4时,会触发熔断降级持续2秒。

效果

 

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/125224590

智能推荐

dos下关于按照日期格式导出数据库dmp文件-程序员宅基地

文章浏览阅读223次。[code="c"]set /A dt=%date:~0,4%%date:~5,2%%date:~8,2%-10set expdt=%DATE:~0,4%%DATE:~5,2%%DATE:~8,2%%TIME:~0,2%%TIME:~3,2%del *%dt%*exp lg_dbwizard/lg1qaz@oanet_172.23.8.37 file=d:\dmp\am\l..._数据库导出dmp文件可以选择数据日期吗

ffmpeg java 压缩视频_java 使用ffmpeg压缩视频-程序员宅基地

文章浏览阅读100次。1.在linux下使用的话,需要导入jave包//java代码private boolean ffmpegChange1 (File file,File fileSave){try{AudioAttributes audio = new AudioAttributes();audio.setCodec("libmp3lame");audio.setBitRate(new Integer(56000..._ffmpeg压缩视频获取进度java

PCM音频实时播放:音频字节数组(16/8位)转为PCM ArrayBuffer流_实时播放pcm数据流-程序员宅基地

文章浏览阅读2.8k次,点赞2次,收藏6次。PCM音频实时播放:音频字节数组(16/8位)转为PCM ArrayBuffer流_实时播放pcm数据流

陷波滤波器设计_陷波器设计-程序员宅基地

文章浏览阅读2.3w次,点赞15次,收藏166次。在信号处理中经常要把某些单频(窄带)干扰信号去除,例如求系统采集信号中的把工频信号滤除。实际上有一个很好的方法,便是使用陷波器。陷波器是一种特殊的带阻滤波器,陷波滤波器主要用于消除某个特定频率的干扰,数字陷波器一般为IIR滤波器。由于陷波器频率特性的特殊性,它除了可采用双线性变换进行设计外,还可以采用所谓零极点配置的方法进行设计。陷波滤波器是无限冲击响应(IIR)数字滤波器,该滤波器可以用以下线性差分方程表示:陷波滤波器的理想频率特性曲线如下图所示:图1 陷波滤波器的理想频率特性曲线_陷波器设计

get_magic_quotes_gpc() 函数-程序员宅基地

文章浏览阅读605次。在php的配置文件中,有个布尔值的设置,就是magic_quotes_runtime,当它打开时,php的大部分函数自动的给从外部引入的(包括数据库或者文件)数据中的溢出字符加上反斜线。 当然如果重复给溢出字符加反斜线,那么字符串中就会有多个反斜线,所以这时就要用set_magic_quotes_runtime()与get_magic_quotes_runtime()设置和检测php.

tensorflow pb格式模型预测规范写法。不然耗时多,或者内存溢出_self.sess.graph.as_default()加入名字-程序员宅基地

文章浏览阅读654次。背景:加载pb格式模型文件并预测解决方法:要声明新的图和session并复用,# 加载 self.graph = tf.Graph() # 为每个类(实例)单独创建一个graphwith self.graph.as_default(): output_graph_def = tf.GraphDef() pb_path = wenlp_configs["sentence_matcher"]["pb_model_path"] with open(pb_path, ._self.sess.graph.as_default()加入名字

随便推点

VsCode预览Geojson数据_vscode展示json数据-程序员宅基地

文章浏览阅读511次。VsCode预览Geojson数据。_vscode展示json数据

KITTI数据集下载链接-程序员宅基地

文章浏览阅读1.9w次,点赞21次,收藏87次。1、简介KITTI数据集由德国卡尔斯鲁厄理工学院和丰田美国技术研究院联合创办,是目前国际上最大的自动驾驶场景下的计算机视觉算法评测数据集。该数据集用于评测立体图像(stereo),光流(optical flow),视觉测距(visual odometry),3D物体检测(object detection)和3D跟踪(tracking)等计算机视觉技术在车载环境下的性能。KITTI包含市区、乡村和高速公路等场景采集的真实图像数据,每张图像中最多达15辆车和30个行人,还有各种程度的遮挡与截..._kitti数据集下载

SpringBoot banner_springbootbanner-程序员宅基地

文章浏览阅读177次。Spring Boot 打印banner当应用启动时,可以显示应用图标,版本,名称等相关信息,可以通过配置文件指定banner打印模式:spring: main: banner-mode: OFF,CONSOLE,LOG具体流程如下SpringApplication.run(String… args) 执行打印banner入口,SpringApplication:public ConfigurableApplicationContext run(String... args) { _springbootbanner

【网络安全】逻辑漏洞保姆级讲解_安全圈 王师傅 逻辑漏洞-程序员宅基地

文章浏览阅读2k次,点赞53次,收藏56次。逻辑漏洞超强解读_安全圈 王师傅 逻辑漏洞

stc单片机c语言程序头文件(stc12c5a60s2.h,stc12c5a60s2头文件在keil中没法用?-程序员宅基地

文章浏览阅读2.2k次。下面那段程序,头文件是编译正常在stc89c52中正常运行,当然在stc12c5a32s2中不行,就是我上次提的问题。我把头文件改成编译出错,提示:Build target '目标 1'assembling STARTUP.A51...compiling 舵机回中.c...舵机回中.C(33): error C202: 'P2_7': undefined identifier舵机回中.C(35):..._assembling startup.a51... compiling main.c... main.c(3): error c202: 'p3': u

spring---数据库连接池druid进行数据库操作、事务回滚_@repository的数据库操作会在同一个数据库连接池进行吗?-程序员宅基地

文章浏览阅读3.4k次。目录使用数据库连接池druid进行数据库操作数据库事务异常回滚----配置方式和注解方式附:开启 spring 的所有注解支持一、使用数据库连接池druid进行数据库操作1.导包<!-- https://mvnrepository.com/artifact/org.springframework/spring-jdbc --> <dependency>..._@repository的数据库操作会在同一个数据库连接池进行吗?