Sentinel第四篇(Sentinel降级-RT)

Sentinel降级-RT

一、是什么

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

二、测试

  • 代码
    在cloudalibaba-sentinel-service8401工程中的FlowLimitController类中添加以下测试接口
@GetMapping("/testD")
    public String testD(){
        try {
            TimeUnit.SECONDS.sleep(1);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return "------test RT";
    }
  • 配置
    Sentinel第四篇(Sentinel降级-RT)_第1张图片

  • jemeter压力测试:

    • 设置每秒请求数:
      Sentinel第四篇(Sentinel降级-RT)_第2张图片
    • 设置url路径
      Sentinel第四篇(Sentinel降级-RT)_第3张图片
  • 测试
    1.未使用jemeter情况下测试/testD接口
    Sentinel第四篇(Sentinel降级-RT)_第4张图片
    2.使用jemeter情况下测试/testD接口
    Sentinel第四篇(Sentinel降级-RT)_第5张图片
    结果:
    访问失败
    Sentinel第四篇(Sentinel降级-RT)_第6张图片

  • 结论
    按照上述配置,永远一秒钟打进来10个线程(大于5个了)调用testD,我们希望200毫秒处理完本次任务,如果超过200毫秒还没处理完,在未来1秒钟的时间窗口内,断路器打开(保险丝跳闸)微服务不可用,保险丝跳闸断电了
    后续我停止jmeter,没有这么大的访问量了,新路器关闭(保险丝恢复),微服务恢复OK

你可能感兴趣的:(SpringCloud,Alibaba,Sentinel,spring,cloud,alibaba)