欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > 名人名企 > 如何使用redis做限流(golang实现小样)

如何使用redis做限流(golang实现小样)

2025/5/28 3:10:36 来源:https://blog.csdn.net/weixin_42738495/article/details/148105757  浏览:    关键词:如何使用redis做限流(golang实现小样)

在实际开发中,限流(Rate Limiting)是一种保护服务、避免接口被恶意刷流的常见技术。常用的限流算法有令牌桶、漏桶、固定窗口、滑动窗口等。由于Redis具备高性能和原子性操作,常常被用来实现分布式限流。

下面给出使用Golang结合Redis实现简单限流的几种常见方式(以“固定窗口计数”和“滑动窗口”为例)。使用的Go Redis库为go-redis。


1. 固定窗口计数(Fixed Window Counter)

在单位时间窗口(如1秒、1分钟)内计数,超过阈值则限流。

伪代码思路:

  1. 用Redis的INCR自增某个key记录当前窗口内的访问次数。
  2. 使用EXPIRE设置Key过期时间为窗口大小。
  3. 如果计数超过阈值,说明被限流。

Go代码示例:

package mainimport ("context""fmt""github.com/redis/go-redis/v9""time"
)var ctx = context.Background()func FixedWindowRateLimit(client *redis.Client, key string, limit int, window time.Duration) (bool, error) {// 每次请求自增计数cnt, err := client.Incr(ctx, key).Result()if err != nil {

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词