Spring Cloud(二十四):Sentinel降级规则

1. 基本介绍

在这里插入图片描述

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

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

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

Sentinel熔断降级会在调用链路中的某个资源出现不稳定状态时(例如调用超时或者异常比例升高,对这个资源的调用进行限制,让请求快速失败),避免影响到其他的资源而导致级联错误。

当资源被降级后,在接下来的降级时间窗口之内,对该资源的调用都是自动熔断(默认行为是抛出DegradeException)

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

2. 降级策略

2.1 RT

在这里插入图片描述
在这里插入图片描述
测试
controller 添加方法

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

在这里插入图片描述
在这里插入图片描述
结论:
按照上述配置,
永远一秒钟进来的10个线程(大于5个)调用testD,我们希望200毫秒处理完本次任务,
如果超过200毫秒还没处理完,在未来1秒的时间窗口内,断路器打开微服务不可用

停止jmeter,没有这么大的访问量了,断路器关闭,微服务恢复

2.2 异常比例

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

测试
controller 添加方法

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

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

2.3 异常数

异常数是按照分钟统计的

controller 添加方法

@GetMapping("/testF")
public String testF() {

    log.info("testF 测试 异常比例");
    int age = 10/0;
    return "------testF";
}

配置
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
第一次访问绝对报错,因为除数不能为0,我们看到error窗口,但是达到5次报错后,进入熔断后降级。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值