Sentinel网关限流规则与API分组配置详解

需积分: 0 0 下载量 163 浏览量 更新于2024-08-05 收藏 549KB PDF 举报
"Sentinel API Gateway 限流适配器模块用于实现网关限流功能,包括自定义API分组和规则,支持基于Route ID、API分组名称、QPS阈值、间隔时间等参数进行限流控制。" 在API网关的流量管理中,SentinelAPIGatewayAdapterCommon模块扮演着至关重要的角色。这个模块专门设计来处理API Gateway的限流规则和用户自定义API的管理。其中,`GatewayFlowRule`是核心的限流规则实体,它允许我们根据不同的条件对API Gateway的流量进行精细控制。 1. **API类型**:可以基于`RoutID`或`API分组`来设定限流策略。`RoutID`对应于具体的API路由,而`API分组`则是用户根据需求定义的一组URL路径,方便统一管理限流策略。 2. **API名称**:可以是`RoutID`或者自定义的`API分组名称`,用于标识需要限流的API或分组。 3. **阈值类型**:通常选择`QPS`(每秒请求数量)作为衡量流量的指标。`QPS阈值`设定了允许通过的请求数量上限。 4. **QPS阈值**:设定的QPS值决定了在特定时间窗口内能通过的最大请求数。 5. **间隔时间**:限流统计的时间窗口,可以是秒、时、分,决定了计算QPS的频率。 6. **资源模式**(`resourceMode`):可以选择是基于`ROUTE_ID`的资源,即API Gateway的路由,或是基于`CUSTOM_API_NAME`的用户自定义API分组。 7. **限流指标维度**(`grade`):决定了限流的计算方式,可以是瞬间流量(如并发线程数)或平均流量(如滑动窗口内的QPS)。 8. **控制效果**(`controlBehavior`):包括快速失败和匀速排队两种模式,快速失败会在超过阈值时立即拒绝请求,而匀速排队则会尝试让请求等待,直到有空闲资源可用。 9. **额外请求数**(`burst`):在应对突发流量时,系统允许的额外请求数,用以缓冲瞬间的高流量。 10. **最长排队时间**(`maxQueueingTimeoutMs`):仅在匀速排队模式下生效,表示请求最多可以等待的毫秒数。 11. **参数限流配置**(`paramItem`):允许根据请求的参数、Header、来源IP等进行定制化限流。例如,可以设置只针对某个特定IP或Header值的请求进行限流。 Sentinel API Gateway 的这些特性使得开发者能够灵活地对API流量进行控制,保护后端服务免受过载影响,同时还能根据业务需求调整限流策略,确保服务的稳定性和性能。通过Sentinel提供的这些工具,我们可以创建出更加健壮和安全的微服务架构。