Spring Cloud Gateway不同频率限流的解决方案(每分钟,每小时,每天)
SpringCloudGateway简介
SpringCloudGateway是SpringCloud的一个全新项目,该项目是基于Spring5.0,SpringBoot2.0和ProjectReactor等技术开发的网关,它旨在为微服务架构提供一种简单有效的统一的API路由管理方式。
SpringCloudGateway作为SpringCloud生态系统中的网关,目标是替代Zuul,在SpringCloud2.0以上版本中,没有对新版本的Zuul2.0以上最新高性能版本进行集成,仍然还是使用的Zuul2.0之前的非Reactor模式的老版本。而为了提升网关的性能,SpringCloudGateway是基于WebFlux框架实现的,而WebFlux框架底层则使用了高性能的Reactor模式通信框架Netty。
SpringCloudGateway的目标,不仅提供统一的路由方式,并且基于Filter链的方式提供了网关基本的功能,例如:安全,监控/指标,和限流。
提前声明:SpringCloudGateway底层使用了高性能的通信框架Netty。
SpringCloudGateway特征
SpringCloud官方,对SpringCloudGateway特征介绍如下:
(1)基于SpringFramework5,ProjectReactor和SpringBoot2.0
(2)集成Hystrix断路器
(3)集成SpringCloudDiscoveryClient
(4)Predicates和Filters作用于特定路由,易于编写的Predicates和Filters
(5)具备一些网关的高级功能:动态路由、限流、路径重写
从以上的特征来说,和Zuul的特征差别不大。SpringCloudGateway和Zuul主要的区别,还是在底层的通信框架上。
简单说明一下上文中的三个术语:
(1)Filter(过滤器):
和Zuul的过滤器在概念上类似,可以使用它拦截和修改请求,并且对上游的响应,进行二次处理。过滤器为org.springframework.cloud.gateway.filter.GatewayFilter类的实例。
(2)Route(路由):
网关配置的基本组成模块,和Zuul的路由配置模块类似。一个Route模块由一个ID,一个目标URI,一组断言和一组过滤器定义。如果断言为真,则路由匹配,目标URI会被访问。
(3)Predicate(断言):
这是一个Java8的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
其他频率以此类推,调整三个参数即可。
到此这篇关于SpringCloudGateway不同频率限流的解决方案(每分钟,每小时,每天)的文章就介绍到这了,更多相关SpringCloudGateway限流内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!