Spring Cloud Gateway不同频率限流的解决方案(每分钟,每小时,每天)
作者:lizz666 发布时间:2023-01-05 13:49:34
SpringCloud Gateway 简介
SpringCloud Gateway 是 Spring Cloud 的一个全新项目,该项目是基于 Spring 5.0,Spring Boot 2.0 和 Project Reactor 等技术开发的网关,它旨在为微服务架构提供一种简单有效的统一的 API 路由管理方式。
SpringCloud Gateway 作为 Spring Cloud 生态系统中的网关,目标是替代 Zuul,在Spring Cloud 2.0以上版本中,没有对新版本的Zuul 2.0以上最新高性能版本进行集成,仍然还是使用的Zuul 2.0之前的非Reactor模式的老版本。而为了提升网关的性能,SpringCloud Gateway是基于WebFlux框架实现的,而WebFlux框架底层则使用了高性能的Reactor模式通信框架Netty。
Spring Cloud Gateway 的目标,不仅提供统一的路由方式,并且基于 Filter 链的方式提供了网关基本的功能,例如:安全,监控/指标,和限流。
提前声明:Spring Cloud Gateway 底层使用了高性能的通信框架Netty。
SpringCloud Gateway 特征
SpringCloud官方,对SpringCloud Gateway 特征介绍如下:
(1)基于 Spring Framework 5,Project Reactor 和 Spring Boot 2.0
(2)集成 Hystrix 断路器
(3)集成 Spring Cloud DiscoveryClient
(4)Predicates 和 Filters 作用于特定路由,易于编写的 Predicates 和 Filters
(5)具备一些网关的高级功能:动态路由、限流、路径重写
从以上的特征来说,和Zuul的特征差别不大。SpringCloud Gateway和Zuul主要的区别,还是在底层的通信框架上。
简单说明一下上文中的三个术语:
(1)Filter(过滤器):
和Zuul的过滤器在概念上类似,可以使用它拦截和修改请求,并且对上游的响应,进行二次处理。过滤器为org.springframework.cloud.gateway.filter.GatewayFilter类的实例。
(2)Route(路由):
网关配置的基本组成模块,和Zuul的路由配置模块类似。一个Route模块由一个 ID,一个目标 URI,一组断言和一组过滤器定义。如果断言为真,则路由匹配,目标URI会被访问。
(3)Predicate(断言):
这是一个 Java 8 的 Predicate,可以使用它来匹配来自 HTTP 请求的任何内容,例如 headers 或参数。断言的输入类型是一个 ServerWebExchange。
正文
在使用SCG限流功能时,默认情况下是按秒限流,即一秒允许多少个请求,现需要根据不同时间频率进行限流,即限制每分钟、每小时或者每天限流。
分析
SCG的限流使用的guava的ratelimiter工具,令牌桶模式,参数包括以下3个:
replenishRate: 每次补充令牌数量
burstCapacity: 令牌桶最大容量,突发请求数量
requestedTokens: 每次请求消耗令牌的数量
使用方案
每秒限制请求1次
- name: RequestRateLimiter #基于redis漏斗限流
args:
key-resolver: "#{@myResolver}"
redis-rate-limiter:
replenishRate: 1
burstCapacity: 1
requestedTokens: 1
每秒限制请求10次
- name: RequestRateLimiter #基于redis漏斗限流
args:
key-resolver: "#{@myResolver}"
redis-rate-limiter:
replenishRate: 10
burstCapacity: 10
requestedTokens: 1
每分钟限制请求1次
- name: RequestRateLimiter #基于redis漏斗限流
args:
key-resolver: "#{@myResolver}"
redis-rate-limiter:
replenishRate: 1
burstCapacity: 60
requestedTokens: 60
每分钟限制请求10次
- name: RequestRateLimiter #基于redis漏斗限流
args:
key-resolver: "#{@myResolver}"
redis-rate-limiter:
replenishRate: 1
burstCapacity: 60
requestedTokens: 6
每小时限制请求1次
- name: RequestRateLimiter #基于redis漏斗限流
args:
key-resolver: "#{@myResolver}"
redis-rate-limiter:
replenishRate: 1
burstCapacity: 3600
requestedTokens: 3600
每小时限制请求10次
- name: RequestRateLimiter #基于redis漏斗限流
args:
key-resolver: "#{@myResolver}"
redis-rate-limiter:
replenishRate: 1
burstCapacity: 3600
requestedTokens: 360
其他频率以此类推,调整三个参数即可。
来源:https://blog.csdn.net/lizz861109/article/details/108980677
猜你喜欢
- 本文实例讲述了Java定义泛型方法。分享给大家供大家参考,具体如下:一 点睛1 如果定义类、接口是没有使用类型形参,但定义方法时想自己定义类
- 一、泛型的概念1.1 基础案例泛型在Java中的应用非常广泛,最常见则是在集合容器中,先看下基础用法:public class Generi
- 小编为面试Java程序员的朋友们整理了2017非常热门的面试中的笔试试题,如果你是一个正在准备面试Java程序员的读者,赶快学习一下吧。1,
- 一、Java后端使用MultipartFile@PostMapping(value = "/upload")  
- Spring spring-context-indexer依赖<dependencies> <d
- 路由做Android/iOS原生开发的时候,要打开一个新的页面,你得知道你的目标页面对象,然后初始化一个Intent或者ViewContro
- 问题描述 在某一天打开电脑后,idea里的代码无缘无故地就爆红了,不但spring框架爆红,就
- spring-mybatis获取mapper方式汇总项目背景:pojo下面有一个user实体类Dao包下面写了usermapper.xml
- 先看代码public class TestDemo1 { public static void main(String[] ar
- 这篇文章主要介绍了Java编码摘要算法实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参
- 使用JAVA工程管理越来越多的jar包,担心导错了,多导了,漏导了怎么办?换一个IDE项目后项目会不会出一堆BUG,看的头皮发麻?自己写的代
- 本文实例为大家分享了Struts2框架拦截 器实例的示例代码,供大家参考,具体内容如下在看拦截 器的小例子的前我们先来看看sturts2的原
- 1.根据单个分隔字符用split截取例如string st="GT123_1";string[] sArray=st.s
- SpringBoot2之PUT请求接收不了参数的解决办法,这个问题,关乎两个Filter过滤器,是spring3和3.5之后提供的,目的就是
- java中初始化MediaRecorder实现代码:private boolean initializeVideo() { &
- 用了MyBatis的同行,应该见过foreach,它一般是这样用的:<select id="foreachTest"
- 近期用到了一位师兄写的C++程序,总体功能良好。使用不同的数据测试,发现了一个明显的缺点:大数据量下,预处理过程耗时很长。中科院的某计算集群
- 一. SpringBoot中实现Session共享1. 创建web项目我们按照之前的经验,创建一个web程序,并将之改造成Spring Bo
- jwt简介冒泡排序:(Bubble Sort)是一种简单的交换排序。之所以叫做冒泡排序,因为我们可以把每个元素当成一个小气泡,根据气泡大小,
- 如下所示: /** * 判断某个界面是否在前台 * * @param context