Spring Cloud Gateway限流极速部署:3步搞定,秒级防护微服务!
Spring Cloud Gateway限流极速部署:3步搞定,秒级防护微服务!
想要快速为Spring Cloud Gateway集成限流功能?本文提供最简方案,无需复杂配置,三步即可完成!通过内置的RequestRateLimiter过滤器,结合Redis实现高并发场景下的精准流量控制。
一、环境准备
- 添加核心依赖
在pom.xml中引入Spring Cloud Gateway和Redis Reactive依赖(Redis用于分布式限流):
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis-reactive</artifactId>
</dependency>
- 配置Redis连接
在application.yml中配置Redis地址:
spring:
redis:
host: localhost
port: 6379
二、基础限流配置
令牌桶算法实现
Spring Cloud Gateway默认采用令牌桶算法,通过
RequestRateLimiter过滤器实现:
spring:
cloud:
gateway:
routes:
- id: user-service
uri: lb://user-service
predicates:
- Path=/api/users/**
filters:
- name: RequestRateLimiter
args:
# 令牌桶每秒填充速率(req/s)
redis-rate-limiter.replenishRate: 10
# 突发流量容量(令牌桶大小)
redis-rate-limiter.burstCapacity: 20
# 限流维度解析器(按IP限流)
key-resolver: "#{@ipKeyResolver}"
定义限流维度解析器
创建
KeyResolverBean决定限流维度(如IP、用户ID等):
@Bean
public KeyResolver ipKeyResolver() {
return exchange -> Mono.just(
exchange.getRequest().getRemoteAddress().getHostString()
);
}
三、高级限流策略
多维度组合限流
支持同时配置路径和IP限流:
filters:
- name: RequestRateLimiter
args:
rate-limiter: "compoundRateLimiter"
key-resolver: "#{@pathAndIpKeyResolver}"
自定义组合限流解析器(如将路径和IP拼接为Key):
@Bean
public KeyResolver pathAndIpKeyResolver() {
return exchange -> {
String ip = exchange.getRequest().getRemoteAddress().getHostString();
String path = exchange.getRequest().getURI().getPath();
return Mono.just(ip + ":" + path); // 组合维度生成唯一key
};
}
自定义限流算法
若需替换默认算法(如改用漏桶算法)
实现
RateLimiter接口,重写isAllowed方法
public class CustomRateLimiter extends AbstractRateLimiter<CustomRateLimiter.Config> {
@Override
public Mono<Response> isAllowed(String routeId, String id) {
// 自定义算法逻辑
// 返回Mono.just(Response.of(allowed, remainingTokens))
}
}
在配置中通过SpEL指定自定义类:
args:
rate-limiter: "#{@customRateLimiter}"
四、验证与测试
触发限流
- 使用工具(如JMeter)发送超过
burstCapacity的请求,观察返回429 Too Many Requests状态码
- 使用工具(如JMeter)发送超过
监控Redis数据
- 限流计数器存储在Redis中,键名格式为
request_rate_limiter.{key}.tokens,可通过redis-cli查看实时令牌数量
- 限流计数器存储在Redis中,键名格式为
五、注意事项
- 算法选择
- 令牌桶:允许突发流量,适合应对短时高峰(默认方案)
- 漏桶:平滑流量,强制恒定速率(需自定义实现)
- 分布式一致性
- 生产环境建议使用Redis集群,避免单点故障导致限流失效
- 动态配置
- 结合Nacos可实现限流规则热更新
通过以上步骤,可快速实现基于Spring Cloud Gateway的限流控制。实际项目中建议结合监控系统(如Prometheus)实时观察限流效果,并根据业务需求调整参数。
Spring Cloud Gateway限流极速部署:3步搞定,秒级防护微服务!的更多相关文章
- Spring Cloud Gateway限流实战
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- Spring Cloud 微服务五:Spring cloud gateway限流
前言:在互联网应用中,特别是电商,高并发的场景非常多,比如:秒杀.抢购.双11等,在开始时间点会使流量爆发式地涌入,如果对网络流量不加控制很有可能造成后台实例资源耗尽.限流是指通过指定的策略削减流量, ...
- 深入学习spring cloud gateway 限流熔断
前言 Spring Cloud Gateway 目前,Spring Cloud Gateway是仅次于Spring Cloud Netflix的第二个最受欢迎的Spring Cloud项目(就GitH ...
- spring cloud gateway 限流做法
标题 随风倒十分 反对法
- Spring Cloud Zuul 限流详解(附源码)(转)
在高并发的应用中,限流往往是一个绕不开的话题.本文详细探讨在Spring Cloud中如何实现限流. 在 Zuul 上实现限流是个不错的选择,只需要编写一个过滤器就可以了,关键在于如何实现限流的算法. ...
- Spring Cloud(十二):Spring Cloud Zuul 限流详解(附源码)(转)
前面已经介绍了很多zuul的功能,本篇继续介绍它的另一大功能.在高并发的应用中,限流往往是一个绕不开的话题.本文详细探讨在Spring Cloud中如何实现限流. 在 Zuul 上实现限流是个不错的选 ...
- spring cloud gateway 之限流篇
转载请标明出处: https://www.fangzhipeng.com 本文出自方志朋的博客 在高并发的系统中,往往需要在系统中做限流,一方面是为了防止大量的请求使服务器过载,导致服务不可用,另一方 ...
- Spring Cloud Gateway 网关限流
Spring Cloud Gateway 限流 一.背景 二.实现功能 三.网关层限流 1.使用默认的redis来限流 1.引入jar包 2.编写配置文件 3.网关正常响应 4.网关限流响应 2.自定 ...
- 快速突击 Spring Cloud Gateway
认识 Spring Cloud Gateway Spring Cloud Gateway 是一款基于 Spring 5,Project Reactor 以及 Spring Boot 2 构建的 API ...
- Spring Cloud Alibaba学习笔记(16) - Spring Cloud Gateway 内置的路由谓词工厂
Spring Cloud Gateway路由配置的两种形式 Spring Cloud Gateway的路由配置有两种形式,分别是路由到指定的URL以及路由到指定的微服务,在上文博客的示例中我们就已经使 ...
随机推荐
- 【BUG排查记】HttpUtil和SpringSecurity结合的坑
一.背景 最近为了做微服务高可用和优化上线流程,我参与了一个微服务的改造开发. 主要包括redis切换哨兵模式.接入高可用xxljob集群.配置和升级脚本优化. 二.问题描述 项目改造提测后,测试 ...
- Note -「A. Algebra 24 Aut.」“还有一束日光正在为你送达”
欢迎勘误吖! 喵, 你可以 Ctrl-F 搜 "lww" 获取少量 lww 笑话. (雾 ↓下面这个是我目前用的 LaTeX 宏, 如果需要可以 "Show ...
- c# WPF convert photo to Sketch effects
using the online website https://imagetosketch.com/ <Window x:Class="WpfMosaic.PhotoSketchWi ...
- 开源的分布式事务解决方案-Seata
Seata 是什么? (1)Seata 是一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布式事务服务. (2)在 Seata 开源之前,Seata 对应的内部版本在阿里经济 ...
- Mysql存储引擎Innodb和MyISAM的区别
一.mysql架构 mysql是一个单进程多线程架构的数据库. 二.存储引擎 InnoDB: 支持事务 行锁 读操作无锁 4种隔离级别,默认为repeatable 自适应hash索引 每张表的存储都是 ...
- MPC收藏
收集有关MPC的优秀文章,方便查阅. 同态加密 原理 介绍 程序员的干货!核心理论之同态加密 https://mp.weixin.qq.com/s/1uH0UjnS_Mo8ShXJ-16UXw BGV ...
- 如何解决:Android Studio (version 4.1); Flutter plugin not installed and Dart plugin not installed errors
出现的现象 android studio 4.1已经安装了flutter和dart插件,但是执行 flutter doctor依然报错. [!] Android Studio (version 4.1 ...
- SqlServer性能检测之Sql语句排查
很多时候,我们在用SQL语句查询数据时,难免会漏掉对SQL语句性能的考虑,所以有时就会造成SqlServer服务占用过高的问题,为了大致排查是哪些SQL语句造成的问题,我们可以通过如下SQL查询出最近 ...
- 性能测试-Oceanus 测试FLink mysql到Iceberg性能
一.任务依赖信息 1.mysql测试库信息 地址:127.0.0.1.gomysql_bdg_test 库:bdg_test 表:order_info1 2.iceberg库 hive地址:thrif ...
- FreeSql学习笔记——3.查询
前言 FreeSql中查询的支持非常丰富,包括链式语法,多表查询,表达式函数:写法多种多样,可以使用简单的条件查询.sql查询.联表.子表等方式用于查询数据, 查询的格式也有很丰富,包括单条记录, ...