SpringCloud Alibaba Sentinel实现熔断与限流-微服务(三十一)

导读:本篇文章讲解 SpringCloud Alibaba Sentinel实现熔断与限流-微服务(三十一),希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

降级规则

官网

基本介绍

在这里插入图片描述
RT(平均响应时间,秒级)
平均响应时间 超出阈值 且 在时间窗口内通过的请求>=5,两个条件同时满足后触发降级
窗口期过后关闭断路器
RT最大4900(更大的需要通过-Dcsp.sentinel.statistic.max.rt=XXXX才能生效)

异常比列(秒级)
QPS >= 5 且异常比例(秒级统计)超过阈值时,触发降级;时间窗口结束后,关闭降级

异常数(分钟级)
异常数(分钟统计)超过阈值时,触发降级;时间窗口结束后,关闭降级

进一步说明

Sentinel 熔断降级会在调用链路中某个资源出现不稳定状态时(例如调用超时或异常比例升高),对这个资源的调用进行限制,
让请求快速失败,避免影响到其它的资源而导致级联错误。
当资源被降级后,在接下来的降级时间窗口之内,对该资源的调用都自动熔断(默认行为是抛出 DegradeException)。

Sentinel的断路器是没有半开状态的

  • 半开的状态系统自动去检测是否请求有异常,
    没有异常就关闭断路器恢复使用,
    有异常则继续打开断路器不可用。具体可以参考Hystrix
    复习Hystrix

在这里插入图片描述

降级策略实战

RT

是什么

在这里插入图片描述
在这里插入图片描述

测试

代码

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

配置
在这里插入图片描述
jmeter压测
在这里插入图片描述

结论

在这里插入图片描述
在这里插入图片描述
按照上述配置,

永远一秒钟打进来10个线程(大于5个了)调用testD,我们希望200毫秒处理完本次任务,
如果超过200毫秒还没处理完,在未来1秒钟的时间窗口内,断路器打开(保险丝跳闸)微服务不可用,保险丝跳闸断电了

后续我停止jmeter,没有这么大的访问量了,断路器关闭(保险丝恢复),微服务恢复OK

异常比例

在这里插入图片描述
在这里插入图片描述

测试

代码

 
@GetMapping("/testD")
public String testD()
{
    log.info("testD 测试RT");
    int age = 10/0;
    return "------testD";
}

配置
在这里插入图片描述
jmeter
在这里插入图片描述
结论
按照上述配置,
单独访问一次,必然来一次报错一次(int age = 10/0),调一次错一次;
在这里插入图片描述
开启jmeter后,直接高并发发送请求,多次调用达到我们的配置条件了。
断路器开启(保险丝跳闸),微服务不可用了,不再报错error而是服务降级了。

异常数

是什么
在这里插入图片描述
时间窗口一定要大于等于60秒。
在这里插入图片描述

  • 异常数是按照分钟统计的
    代码
@GetMapping("/testE")
public String testE()
{
    log.info("testE 测试异常比例");
    int age = 10/0;
    return "------testE 测试异常比例";
}

配置
在这里插入图片描述

http://localhost:8401/testE,第一次访问绝对报错,因为除数不能为零,
我们看到error窗口,但是达到5次报错后,进入熔断后降级。

jmeter
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/76946.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!