实现分布式限流开源项目

以下是10个可以实现分布式限流中间件的开源项目推荐,这些项目基于不同的技术栈,适用于多种应用场景:

  1. **Alibaba Sentinel**

Sentinel 是阿里巴巴开源的分布式限流中间件,支持多种限流策略(如QPS、并发线程数等),并可以通过动态规则进行配置。它支持分布式环境下的限流,并且可以与Nacos、Consul等配置中心集成。

  1. **Redisson RRateLimiter**

Redisson 提供了基于Redis的分布式限流器RRateLimiter,底层使用Lua脚本和令牌桶算法实现。它支持Redis单机、Sentinel和Cluster等多种部署方式。

  1. **AspNetCoreRateLimit**

这是一个针对ASP.NET Core的限流中间件,支持基于IP、客户端ID等维度的限流策略。它可以通过配置文件灵活定义限流规则,并支持内存缓存和Redis等多种存储方式。

  1. **Limiter**

Limiter 是一款基于Rack的HTTP请求限流中间件,支持黑白名单功能。它使用Redis进行数据存储,适用于需要限制HTTP请求频率的场景。

  1. **Guava RateLimiter**

Guava 提供了单机限流器RateLimiter,基于令牌桶算法实现。虽然它主要用于单机环境,但可以通过结合Redis等分布式存储实现分布式限流。

  1. **go-ratelimit**

这是一个基于Go语言的限流库,支持漏桶算法。它可以通过简单的API实现限流功能,适用于Go语言开发的分布式系统。

  1. **lua-resty-limit-traffic**

这是一个基于OpenResty/Nginx的限流插件,使用Lua脚本实现。它支持基于Redis的分布式限流,适用于需要在Nginx层面实现限流的场景。

  1. **Spring Cloud Gateway RateLimiter**

Spring Cloud Gateway 提供了限流功能,可以通过与Redis等存储结合实现分布式限流。它支持基于路径、IP等维度的限流策略,适合Spring生态的微服务架构。

  1. **Apache APISIX**

Apache APISIX 是一个高性能的API网关,支持分布式限流。它通过插件机制实现限流功能,支持多种协议和后端服务。

  1. **gRPC-RateLimiter**

这是一个基于gRPC的限流中间件,支持分布式环境下的限流功能。它可以通过配置文件定义限流规则,并支持多种后端存储。

这些项目涵盖了从单机到分布式环境的限流需求,您可以根据具体的技术栈和业务需求选择合适的工具。

相关推荐
冬奇Lab11 小时前
每日一个开源项目(第149篇):RAG-Anything - 把图片、表格、公式当成一等公民的多模态 RAG 框架
人工智能·开源
太阳之子1 天前
给你的 AI Agent 装一双"能上网冲浪"的眼睛
开源
冬奇Lab1 天前
每日一个开源项目(第148篇):obsidian-skills - Obsidian CEO 亲写的 AI Agent 格式规范,让 Agent 不再破坏你的 Vault
人工智能·开源·资讯
程序员老赵2 天前
Docker 部署 Redmine:老牌开源项目管理部署实测记录
docker·开源·团队管理
colir02 天前
被粉丝夸爆的超级 ai 个人工作站,原来这么多福利
开源·agent·claude
程序员老赵2 天前
服务器文件不想 SFTP 上传?Docker 跑个 File Browser,浏览器就能管理
服务器·docker·开源
饼干哥哥2 天前
我把GPT-image-2生成PSD的能力打包成了Skill,免费开源
gpt·开源·ai编程
inhere2 天前
eget:不用等中央仓库,直接安装 GitHub 和任意下载站的工具
程序员·开源·github
redreamSo2 天前
团队 AI 资产总烂在本地?先分清哪些该装、哪些只能连
人工智能·架构·开源
冬奇Lab2 天前
每日一个开源项目(第147篇):HyperGraphRAG - 用超图表示 N 元关系,RAG 的第三代范式
人工智能·开源·graphql