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以及路由到指定的微服务,在上文博客的示例中我们就已经使 ...
随机推荐
- LetsTalk_Android中引导用户加入白名单图
--------------------------------
- TypeScript学习(二) - TypeScript的接口(interface)和类(class)
1. 对象的类型--接口 1.1 什么是接口 1.2 简单的例子 1.3 可选属性 1.4 任意属性 1.5 只读属性 2. 类 2.1 类的概念 2.2 ES6 中类的用法 属性和方法 类的继承 存 ...
- 1. C++快速入门--变量和基本类型, 类别
文章使用obsidian编写, 双链部分可能失效 1 基本内置类型 1.1 算术类型 算术类型介绍 bool 类型 字符类型 整数类型 实数浮点.虚数浮点和 复数浮点 参看如下表 带符号和无符号类型的 ...
- 优化博客Ⅱ-CDN加速
CDN加速 自从有了第一次博客优化经验,我就越发对优化感兴趣了嘿嘿(✧∇✧). 看着博客首页打开时长为1200ms左右,我又开始琢磨有什么办法能再给网站提提速,让访问时间降低到1000ms以下,这时候 ...
- C#利用Vosk开源模型语音识别
#C#利用Vosk开源模型语音识别 #by wgscd 模型下载:VOSK Models (alphacephei.com) 找到chinese Chinese vosk-model- ...
- JAVA多线程和并发性知识点总结
一. 什么是进程.线程?线程和进程的区别?1. 进程当一个程序进入内存运行时,即变成一个进程.进程是处于运行过程中的程序.进程是操作系统进行资源分配和调度的一个独立单位.进程的三个特征: 独立性独立存 ...
- 《Linux shell 脚本攻略》第1章——读书笔记
目录 文件描述符及重定向 函数和参数 迭代器 算术比较 文件系统相关测试 字符串进行比较 文件描述符及重定向 echo "This is a sample text 1" > ...
- 基于Hexo实现一个静态的博客网站
原文首发:https://blog.liuzijian.com/post/8iu7g5e3r6y.html 1.初始化Hexo Hexo是中国台湾开发者Charlie在2012年创建的一个开源项目,旨 ...
- 补充:字符编码ASCII、 ISO8859-1、GB2312、GBK、Unicode、UTF-8
补充:字符编码 编码表的由来计算机只能识别二进制数据,早期由来是电信号.为了方便应用计算机,让它可以识别各个国家的文字.就将各个国家的文字用数字来表示,并一一对应,形成一张表.这就是编码表. 常 ...
- 0101-win10 jkd配置注意事项
更换新的电脑预装win10家庭版,根据常规方法配置jdk8后运行javac提示:不是内部或外部命令,也不是可运行的程序或批处理文件. 1 设置变量classpath时前面有个点(完成这一步后javac ...