sentinel中的burst
时间: 2025-01-01 07:25:28 浏览: 7
### Sentinel Burst 参数含义及用法
#### 定义与作用
Burst参数通常用于描述流量控制中的突发流量处理能力。在Sentinel中,`count`参数定义了QPS(每秒查询数)阈值,而`burst`则允许一定程度上的瞬时超过这个阈值的行为[^3]。
具体来说,在设定限流规则时,除了指定平均速率外还可以设置一个额外的容量——即所谓的“令牌桶”的初始容量或最大可突增的数量。当实际请求频率短时间超过了设定的QPS上限时,只要不超过此附加额度就不会立即触发限流;一旦超出这部分预留空间,则会被认为违反了限流策略并采取相应措施。
#### 使用场景示例
假设有一个API接口希望将其稳定状态下的最大访问速度限制为每秒钟10次调用(`count=10`),但是考虑到业务特性可能会存在短时间内集中爆发的情况,因此可以适当放宽至最多再接受额外5个请求作为缓冲(`burst=5`)。这样既能够保障大多数情况下资源得到合理利用,又能在特殊时刻提供一定的弹性支持而不至于立刻拒绝合法用户的正常操作需求。
```java
// Java代码片段展示如何创建带有burst参数的限流规则
FlowRule rule = new FlowRule();
rule.setResource("exampleApi");
rule.setGrade(RuleConstant.FLOW_GRADE_QPS);
rule.setCount(10); // 平均qps限制
rule.setBurst(5); // 允许的最大突发数量
List<FlowRule> rules = new ArrayList<>();
rules.add(rule);
FlowRuleManager.loadRules(rules);
```
通过这种方式配置之后,对于名为`exampleApi`的服务而言,在任意一秒内如果接收到少于等于15个新请求都将被认为是合理的;只有真正持续性的超负荷才会被严格管控起来。
阅读全文