SpringCloud Gateway限流

本文详细介绍如何在SpringCloud Gateway中实现基于Redis的限流策略,包括IP、API及用户级别的限流,并提供了具体的代码示例和配置说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

网关作为所有请求的入口,请求量大,我们可以通过对并发访问的请求进行限速来保护系统的可用性。

使用的是Spring Cloud Gateway作为网关,分享一下其中的限流操作,目前限流使用的是基于Redis的实现,我们需要增加对应的依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis-reactive</artifactId>
</dependency>

 

定义Spring Cloud Gateway中的key-resolver:“#{@ipAddressKeyResolver}” #SPEL表达式去对应bean,key就是bean要取得名字,如remoteAddrKeyResolver:

IP限流:

/**
	 * 根据 HostName 进行限流
	 * @return
	 */
	@Primary
	@Bean(value = "remoteAddrKeyResolver")
	public KeyResolver remoteAddrKeyResolver() {
		return exchange -> Mono.just(exchange.getRequest().getRemoteAddress().getAddress().getHostAddress());
	}

API限流:

/**
	 * 根据api接口来限流
	 * @return
	 */
	@Bean(name="apiKeyResolver")
	public KeyResolver apiKeyResolver() {
		return exchange ->  Mono.just(exchange.getRequest().getPath().value());
	}

User限流:

/**
	 * 用户限流
	 * 使用这种方式限流,请求路径中必须携带userId参数。
	 *  提供第三种方式
	 * @return
	 */
	@Bean("userKeyResolver")
	KeyResolver userKeyResolver() {
		return exchange -> Mono.just(exchange.getRequest().getQueryParams().getFirst("userId"));
	}

可以根据集体情况自己添加新的限流策略

关于配置,可以在需要限流的服务中增加过滤器信息

server:
 port: 20001
spring:
 redis:
 host: 127.0.0.1
 port: 6379
 cloud:
 gateway:
  routes:
  - id: micro-activity
  uri: lb://micro-activity
  predicates:
  - Path=/api/activity/**
  filters:
  - name: RequestRateLimiter  //名称必须是这个
   args:
   redis-rate-limiter.replenishRate: 100 //允许用户每秒处理多少个请求
   redis-rate-limiter.burstCapacity: 100  //令牌桶的容量,允许在一秒钟内完成的最大请求数(用的是令牌桶算法)
   key-resolver: "#{@ipKeyResolver}" //使用SpEL按名称引用bean
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值