Sentinel 熔断规则 - 异常比例(order & product 示例)笔记

一 核心定义

异常比例熔断是 Sentinel 实现服务容错的核心策略,针对服务间调用异常的场景设计。

以 order(订单服务)调用 product(商品服务)的查询商品库存接口为例:

当 order 服务在指定时间范围内,调用 product 库存接口的异常请求占比达到阈值时,会立即触发熔断机制;在设定的熔断时长内,order 对该接口的所有请求都会被直接拦截,不会发送至 product 服务;熔断时长结束后,会进入试探状态判断服务是否恢复,以此避免异常服务拖垮调用方。

二 关键规则参数

配置异常比例熔断规则,必须明确以下4个核心参数,缺一不可:

1 最小请求数

触发熔断的请求基数门槛。只有当时间窗口内的总请求数达到或超过该数值,才会计算异常比例。

比如设为5,则1秒内 order 调用 product 接口的请求数不足5时,即使全部请求异常,也不会触发熔断。

2 时间窗口

统计异常请求占比的时间范围。Sentinel 会在这个时间范围内累计请求数和异常请求数,计算比例。

比如设为1秒,则每1秒会重新统计一次请求的异常情况。

3 异常比例阈值

触发熔断的临界占比,取值范围在 0.0 - 1.0 之间(如 0.5 代表 50%)。

当时间窗口内的异常请求数 ÷ 总请求数 ≥ 该阈值时,立即触发熔断。

4 熔断时长

触发熔断后拦截请求的持续时间。

比如设为30秒,则熔断触发后的30秒内,order 对 product 库存接口的请求都会被拦截。

三 完整执行流程(order → product 调用场景)

假设配置:最小请求数=5、时间窗口=1秒、异常比例阈值=0.5、熔断时长=30秒

1 正常调用阶段

order 服务持续调用 product 的库存接口,若1秒内请求数不足5,或异常请求占比低于50% → 不触发熔断,请求正常发送。

2 熔断触发阶段

某1秒内 order 发起了10次调用请求,其中6次出现异常(异常占比60% ≥ 50%),且总请求数达到了最小请求数5 → 立即触发熔断。

3 熔断拦截阶段

熔断触发后的30秒内,order 对 product 库存接口的所有请求都会被 Sentinel 拦截,不会真正发送到 product 服务,避免 product 服务在异常状态下被持续请求,减轻其压力。

4 半熔断试探阶段

30秒熔断时长结束后,进入半熔断状态:此时会放行少量请求(如1次)去调用 product 库存接口。

  • 若试探请求正常响应 → 判定 product 服务已恢复,熔断状态解除,恢复正常调用。

  • 若试探请求仍异常 → 判定服务未恢复,重新触发熔断,再次进入30秒拦截期。

四 关键补充说明

1 异常请求判定范围:Sentinel 默认将接口超时、抛出运行时异常、返回错误状态码等情况,判定为"异常请求"。

2 熔断本质:熔断是拦截请求的发送,而非禁止调用逻辑执行。order 服务仍会触发调用接口的代码逻辑,但 Sentinel 会在代码执行过程中阻断请求,不让其发送到 product 服务。

3 配置误区:不要忽略"最小请求数"参数。如果不设置该参数,少量请求的异常(比如1秒内2次请求全部异常)就会触发熔断,容易导致正常业务被误拦截

相关推荐
二哈赛车手3 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
为何创造硅基生物4 小时前
C语言 结构体内存对齐规则(通俗易懂版)
c语言·开发语言
吃好睡好便好4 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
栗子~~4 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
星寂樱易李4 小时前
iperf3 + Python-- 网络带宽、网速、网络稳定性
开发语言·网络·python
YDS8294 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
仰泳之鹅4 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
之歆5 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
未若君雅裁5 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis
cen__y6 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git