Spring Cloud Alibaba Gateway 集成 Redis 限流的完整配置

以下是基于 Spring Cloud Alibaba Gateway 集成 Redis 限流的完整配置:

SpringCloud+全栈Java微服务+分布式,全栈开发springcloud微服务技术栈课程

配置示例

application.ymlbootstrap.yml 中添加以下配置:

yaml 复制代码
spring:
  redis:
    host: localhost
    port: 6379
    password:  # 如果有密码则填写

  cloud:
    gateway:
      routes:
        - id: rate_limit_route
          uri: http://example.com
          predicates:
            - Path=/api/**
          filters:
            - name: RequestRateLimiter
              args:
                redis-rate-limiter.replenishRate: 10  # 每秒允许的请求数
                redis-rate-limiter.burstCapacity: 20  # 峰值请求容量
                redis-rate-limiter.requestedTokens: 1  # 每个请求消耗的令牌数

核心代码实现

SpringCloud+全栈Java微服务+分布式,全栈开发springcloud微服务技术栈课程

1. 添加依赖

确保 pom.xml 包含以下依赖:

xml 复制代码
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-gateway</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis-reactive</artifactId>
</dependency>
2. 自定义限流键解析器

创建 KeyResolver 实现类(例如基于 IP 限流):

java 复制代码
@Bean
public KeyResolver ipKeyResolver() {
    return exchange -> Mono.just(
        exchange.getRequest().getRemoteAddress().getAddress().getHostAddress()
    );
}

SpringCloud+全栈Java微服务+分布式,全栈开发springcloud微服务技术栈课程

3. 注册 KeyResolver

在配置中引用自定义的解析器:

yaml 复制代码
filters:
  - name: RequestRateLimiter
    args:
      key-resolver: "#{@ipKeyResolver}"
      redis-rate-limiter.replenishRate: 10
      redis-rate-limiter.burstCapacity: 20

验证限流效果

访问 /api/ 开头的接口时:

  • 正常情况:每秒允许 10 个请求
  • 突发流量:最高允许 20 个请求(超出后返回 HTTP 429 状态码)

SpringCloud+全栈Java微服务+分布式,全栈开发springcloud微服务技术栈课程

注意事项

  1. Redis 需保持可用状态
  2. 可通过调整 burstCapacity 应对突发流量
  3. 自定义 KeyResolver 可实现用户级/接口级等精细化限流
相关推荐
NocoBase5 分钟前
【2.0 教程】第 1 章:认识 NocoBase ,5 分钟跑起来
数据库·人工智能·开源·github·无代码
sayang_shao1 小时前
ARM架构运行模式学习笔记
arm开发·学习·架构
颜酱1 小时前
DFS 岛屿系列题全解析
javascript·后端·算法
Hoshino.412 小时前
基于Linux中的数据库操作——下载与安装(1)
linux·运维·数据库
一叶飘零_sweeeet2 小时前
服务注册发现深度拆解:Nacos vs Eureka 核心原理、架构选型与生产落地
微服务·云原生·eureka·nacos·架构·注册中心
小码哥_常2 小时前
Java后端定时任务抉择:@Scheduled、Quartz、XXL - Job终极对决
后端
uzong2 小时前
Skill 被广泛应用,到底什么是 Skill,今天详细介绍一下
人工智能·后端·面试
小码哥_常2 小时前
Kafka平替!SpringBoot+Redis Stream+消费组打造极致消息队列
后端
Tadas-Gao3 小时前
Mem0分层记忆系统:大语言模型长期记忆的架构革命与实现范式
人工智能·语言模型·自然语言处理·架构·大模型·llm·transformer
Oueii3 小时前
Django全栈开发入门:构建一个博客系统
jvm·数据库·python