Sentinel入门与进阶:微服务流量控制的最佳实践 ( 五 )

7. 熔断降级

Sentinel除了流量控制以外,对调用链路中不稳定的资源进行熔断降级也是保障高可用的重要措施之一。

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

Sentinel 和 Hystrix 的原则是一致的: 当调用链路中某个资源出现不稳定,例如,表现为 timeout,异常比例升高的时候,则对这个资源的调用进行限制,并让请求快速失败,避免影响到其它的资源,最终产生雪崩的效果。

由于网络或者自身的原因,我们的服务并不能保证100%可用,如果某个服务出现问题,调用这个服务就会出现阻塞的现象,此时,如果有大量请求涌入,线程资源就会消耗殆尽,导致微服务整体瘫痪,这时我们就要考虑服务不可用时的处理方式,也就是熔断和降级。我们先说降级。我们关闭nacos-server服务来制造这种场景。

限流降级指标有三个,如下图:

  1. 慢调用比例

  2. 异常比例

  3. 异常数

在这里插入图片描述

7.1. 慢调用比例

慢调用比例 (DEGRADE_GRADE_RT):当资源的平均响应时间超过阈值DegradeRule 中的 count,以 ms 为单位,默认上限是4900ms)之后,资源进入准降级状态。如果1s之内持续进入 5 个请求,它们的 RT 都持续超过这个阈值,那么在接下来的时间窗口DegradeRule 中的 timeWindow,以 s 为单位)之内,对这个方法的调用都会自动地返回(抛出 DegradeException)。在下一个时间窗口到来时, 会接着再放入5个请求, 再重复上面的判断。

7.1.1.配置中心:超时时间100ms,熔断时间10s

[
    {
   
        "resource":"/sentinelTest/sayHello",
        "grade": 0,
        "count": 100,
        "timeWindow": 10,
        "minRequestAmount": 5 
    }
]

在这里插入图片描述

7.1.2.项目中增加 配置

spring.cloud.sentinel.datasource.ds-degrade.nacos.server-addr=127.0.0.1:8848
spring.cloud.sentinel.datasource.ds-degrade.nacos.data-id=${spring.application.name}-sentinel-degrade
spring.cloud.sentinel.datasource.ds-degrade.nacos.group-id=DEFAULT_GROUP
spring.cloud.sentinel.datasource.ds-degrade.nacos.rule-type=degrade
spring.cloud.sentinel.datasource.ds-degrade.nacos.data-type=json

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值