开发者社区 > 云原生 > 正文

sentinel 触发熔断的问题

在使用异常比例进行熔断时,当熔断结束并恢复之后,在一开始的几笔交易中:

情况一:如果连续失败且失败次数<5,不会再次进入熔断,失败次数达到5笔,尝试第六笔交易时,会进入熔断

情况二:如果恢复后的第一笔交易失败,而第二笔交易成功,在尝试第三笔交易时就会立刻进入失败。我配置的是50%的异常比例。(如果连续失败N笔,N<5,N+1笔成功后,N+1笔会进入熔断)

针对情况一:我认为应该熔断恢复后仍然失败应该继续熔断 针对情况二:同情况一

如何操作:

1、配置熔断为异常比例,比例值我配的是 50%,timewindow 为 2s

2、触发熔断

3.1 控制熔断后的N笔交易为失败(N<5),其余为成功

3.2 控制熔断后的N笔交易为失败(N<4),N+1笔为成功

其实连续失败5次后才熔断的逻辑我认为是正常的,因为是判定一秒内至少有五笔请求才会去判断熔断逻辑。但是让人感到诡异的是,熔断恢复后如果第一笔失败,第二笔成功,只要我配置的熔断比例值<50,就一定会触发熔断。(不过看了一下源码好像是因为触发 熔断判断的五笔请求 是包含mock方法的,但mock方法的结果既不是成功也不是异常)

原提问者GitHub用户Warkeeper

展开
收起
码字王 2023-05-19 17:08:29 119 0
1 条回答
写回答
取消 提交回答
  • 这一点在1.8.x中得到了改进(具有半打开状态)。您可以参考最新的文档:https://github.com/alibaba/Sentinel/wiki/Circuit-Breaking

    原回答者GitHub用户sczyh30

    2023-05-19 21:15:27
    赞同 展开评论 打赏
问答分类:
问答标签:
问答地址:

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

相关电子书

更多
阿里云容器 AHAS Sentinel 网关流控揭秘 立即下载
workshop专场-微服务专场-开发者动手实践营-微服务-使用Sentinel进行微服务流量控制 立即下载
Sentinel分布式系统下的流量防卫兵 立即下载