Gloo Gateway 速率限制配置指南
2025-06-12 06:48:37作者:蔡丛锟
前言
在现代微服务架构中,API 速率限制是保护后端服务免受突发流量冲击的重要手段。Gloo Gateway 提供了多种速率限制方案,可以满足不同场景下的需求。本文将详细介绍如何在 Gloo Gateway 中配置和使用速率限制功能。
环境准备
在开始配置速率限制前,需要确保以下环境已就绪:
- 已部署 Kubernetes 集群
- 已安装 Gloo Gateway(企业版或开源版)
- 已部署测试应用(如 Pet Store 示例应用)
速率限制 API 选择
Gloo Gateway 提供了三种速率限制 API,各有特点:
1. Envoy API
适用版本:开源版和企业版
特点:
- 基于描述符(descriptors)和动作(actions)的配置方式
- 描述符的顺序很重要,必须完全匹配才会触发限制
- 适合大多数常规速率限制场景
示例场景:
- 限制带有
x-type头的请求 - 限制同时带有
x-type和x-number: 5头的请求
2. Set-Style API
适用版本:仅企业版
特点:
- 同样基于描述符和动作,但描述符是无序的
- 支持通配符匹配
- 适合更复杂的速率限制场景
- 可与 Envoy API 同时使用
示例场景:
- 限制带有
x-type: a头的请求 - 限制带有
x-number: 1头的请求 - 限制带有任意
x-color头的请求
3. Gloo Gateway API
适用版本:仅企业版
特点:
- 最简单的配置方式
- 直接在虚拟服务中指定限制规则
- 支持区分认证和匿名请求
- 适合简单的按路由或主机的限制需求
速率限制实现方案
方案一:使用 RateLimitConfig 资源(仅企业版)
这是企业版推荐的配置方式,可以集中管理速率限制规则并在多个虚拟服务中复用。
配置步骤:
- 创建 RateLimitConfig 资源定义规则:
apiVersion: ratelimit.solo.io/v1alpha1
kind: RateLimitConfig
metadata:
name: my-rate-limit-policy
namespace: gloo-system
spec:
raw:
descriptors:
- key: generic_key
value: counter
rateLimit:
requestsPerUnit: 1
unit: MINUTE
rateLimits:
- actions:
- genericKey:
descriptorValue: counter
- 在虚拟服务中引用该规则:
apiVersion: gateway.solo.io/v1
kind: VirtualService
metadata:
name: default
namespace: gloo-system
spec:
virtualHost:
options:
rateLimitConfigs:
refs:
- name: my-rate-limit-policy
namespace: gloo-system
方案二:分离式配置(开源版和企业版)
这种方式需要在 Settings 资源中定义描述符,在虚拟服务中定义动作。
配置步骤:
- 更新 Settings 资源定义描述符:
spec:
ratelimit:
descriptors:
- key: generic_key
value: "per-minute"
rateLimit:
requestsPerUnit: 1
unit: MINUTE
- 在虚拟服务中定义动作:
spec:
virtualHost:
options:
ratelimit:
rateLimits:
- actions:
- genericKey:
descriptorValue: "per-minute"
方案三:Gloo Gateway 简单 API(仅企业版)
配置步骤:
spec:
virtualHost:
options:
ratelimitBasic:
anonymous_limits:
requests_per_unit: 1
unit: MINUTE
authorized_limits:
requests_per_unit: 1000
unit: SECOND
验证配置
应用配置后,可以通过以下命令验证虚拟服务的配置:
kubectl describe vs default -n gloo-system
最佳实践
- 测试环境:建议先在测试环境验证速率限制规则
- 渐进式部署:生产环境可以先设置较宽松的限制,再逐步收紧
- 监控:结合监控指标观察速率限制效果
- 日志:启用访问日志记录被限制的请求
总结
Gloo Gateway 提供了灵活的速率限制方案,从简单的全局限制到复杂的基于多条件的限制都能支持。企业用户可以根据需求选择最适合的 API 类型,而开源用户可以使用 Envoy API 满足基本需求。正确配置速率限制可以有效保护后端服务,提升系统稳定性。
登录后查看全文
热门项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
FreeSql功能强大的对象关系映射(O/RM)组件,支持 .NET Core 2.1+、.NET Framework 4.0+、Xamarin 以及 AOT。C#00
热门内容推荐
最新内容推荐
项目优选
收起
deepin linux kernel
C
27
14
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
659
4.26 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.54 K
894
Ascend Extension for PyTorch
Python
503
609
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
391
286
暂无简介
Dart
905
218
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
昇腾LLM分布式训练框架
Python
142
168
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
939
862
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
1.33 K
108