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


猜你喜欢
- @Scheduled多个任务同时开始执行只需在springBoot启动类上添加如下代码即可:@Bean publi
- 新建SL4 应用程序,在MainPage下添加代码:<Button x:Name="btnThread1" Cli
- C#实现组合排列的方法  
- 省流/// <summary>/// 是否有效的文件,文件夹路径/// </summary>/// <para
- 今天在于硬件进行交互的过程中,要到了了需要两个数组进行合并,然后对数组进行反转和加密操作,以下是两个byte数组合并的方法。/** *
- NPOI是一个开源的C#读写Excel、WORD等微软OLE2组件文档的项目。使用 NPOI 可以在没有安装 Office 或者相应环境的机
- ForkJoin简介Fork/Join框架是Java 7提供的一种用于并行执行任务的框架,它将大任务分解为若干个小任务,并行执行这些小任务,
- AspectJ 是通过注解来描述切点与增强的。1 开发环境要求因为要使用注解,所以请确保使用的 Java5.0 及以上版本。引入 Aspec
- 什么是FTPFTP(File Transfer Protocol)是TCP/IP网络上两台计算机传送文件的协议,使得主机间可以共享文件.可以
- 一、MyBatisPlusConfig中配置分页插件/** * 配置分页插件 * @
- @MapperScan包扫描的坑在使用通用mapper执行查询时,由于不太注意顺手就导了spring的包:import org.mybati
- 前言我们一说到spring,可能第一个想到的是 IOC(控制反转) 和 AOP(面向切面编程)。没错,它们是spring的基石,得益于它们的
- 服装价格变动,触发淘宝发布活动和消费者购买衣服事件流public class EventStandard { &n
- 一、template下文件不允许直接访问1、查资料得知:springboot项目默认是不允许直接访问template下的文件的,是受保护的。
- 1.一级指针#include?<stdio.h>int?main(){?int?data?=?10;?int?*p1?=?&am
- 如何:对 Windows 窗体控件进行线程安全调用访问 Windows 窗体控件本质上不是线程安全的。 如果有两个或多个线程操作某一控件的状
- java类的方法,我特别喜欢《java编程思想》里面的描述,这本书说java类之间的相互通信是通过消息。比如顾客类的对象调用一个eat方法,
- 读XMLXmlDocument xd = new XmlDocument(); string fi
- Java调用cmd命令,并输出显示信息:package com.anxin.cmd.test; import java.io.Buffere
- 你是否遇到过应用程序性能下降的问题?有没有想过提升Spring性能?如果是这样 - 那么这篇文章绝对适合你。在这里,我们将谈论使用超级强大和