Spring Cloud Gateway不同频率限流的解决方案(每分钟,每小时,每天)

 更新时间:2020年10月10日 10:39:12   作者:lizz666  
SpringCloud Gateway 是 Spring Cloud 的一个全新项目,它旨在为微服务架构提供一种简单有效的统一的 API 路由管理方式。这篇文章主要介绍了Spring Cloud Gateway不同频率限流(每分钟,每小时,每天),需要的朋友可以参考下

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

其他频率以此类推,调整三个参数即可。

到此这篇关于Spring Cloud Gateway不同频率限流的解决方案(每分钟,每小时,每天)的文章就介绍到这了,更多相关Spring Cloud Gateway限流内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JAVA spark创建DataFrame的方法

    JAVA spark创建DataFrame的方法

    这篇文章主要介绍了JAVA spark创建DataFrame的方法,帮助大家更好的理解和学习spark,感兴趣的朋友可以了解下
    2020-08-08
  • 利用Java手写一个简易的lombok的示例代码

    利用Java手写一个简易的lombok的示例代码

    Lombok是一款Java开发插件,使得Java开发者可以通过其定义的一系列注解来消除业务工程中冗长和繁琐的代码,尤其对于简单的Java模型对象。本文就来手写一个简易的lombok,需要的可以参考一下
    2022-10-10
  • MyBatisPlus报错:Failed to process,please exclude the tableName or statementId问题

    MyBatisPlus报错:Failed to process,please exclud

    这篇文章主要介绍了MyBatisPlus报错:Failed to process,please exclude the tableName or statementId问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Java实现二分查找BinarySearch算法

    Java实现二分查找BinarySearch算法

    这篇文章主要介绍了Java实现二分查找BinarySearch算法,二分查找针对的是一个有序的数据集合,每次都通过跟区间的中间元素对比,将待查找的区间缩小为之前的一半,直到找到要查找的元素,或者区间被缩小为 0,需要的朋友可以参考下
    2023-12-12
  • 关于IDEA配置Hibernate中遇到的问题解决

    关于IDEA配置Hibernate中遇到的问题解决

    这篇文章主要给大家介绍了关于IDEA配置Hibernate中遇到的问题,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-05-05
  • Java将本地项目部署到Linux服务器的实践

    Java将本地项目部署到Linux服务器的实践

    本文主要介绍了Java将本地项目部署到Linux服务器的实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧<BR>
    2022-06-06
  • 关于MyBatis10种超好用的写法(收藏)

    关于MyBatis10种超好用的写法(收藏)

    这篇文章主要介绍了关于MyBatis10种超好用的写法(收藏),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • idea使用Vim的技巧大全分享

    idea使用Vim的技巧大全分享

    vim是一个高度可配置的文本编辑器,非常稳定,可以高效的创建任何文本、持久的、多级撤销树、支持数百种变成语言和格式、与许多工具集成,本文给大家分享了idea使用Vim的技巧大全,需要的朋友可以参考下
    2024-05-05
  • 使用maven基本命令,打包包名问题

    使用maven基本命令,打包包名问题

    这篇文章主要介绍了使用maven基本命令,打包包名问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • SpringBoot @RequestParam、@PathVaribale、@RequestBody实战案例

    SpringBoot @RequestParam、@PathVaribale、@RequestBody实战案例

    这篇文章主要介绍了SpringBoot @RequestParam、@PathVaribale、@RequestBody实战案例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11

最新评论