Spring cloud gateway流控

本文介绍了Spring Cloud Gateway的流量控制原理,通过添加Redis依赖并配置相关参数实现限流。在配置中,`replenishRate`表示每秒填充速率,`burstCapacity`表示允许的最大突发量。文章还提到了默认的RedisRateLimiter实现,包括lua脚本的使用,以及如何自定义过滤器进行流量控制。
摘要由CSDN通过智能技术生成

1.工作原理上图
在这里插入图片描述
2.增加依赖

org.springframework.boot
spring-boot-starter-data-redis-reactive

Application.yml增加配置

  • name: RequestRateLimiter #必须使用此名称做为限流控制
    args:
    #限流最大请求数
    redis-rate-limiter.replenishRate: 10
    #允许溢出量
    redis-rate-limiter.burstCapacity: 20
    此处注意burstCapacity值越大,replenishRate越小,redis中存放数据的key时间越长
    local fill_time = capacity/rate
    local ttl = math.floor(fill_time*2) ttl为key值有效期。

3.默认实现RedisRateLimiter
1、重要参数配置
args:
redis-rate-limiter.replenishRate: 10
redis-rate-limiter.burstCapacity: 5
key-resolver: “#{@userKeyResolver}” #redis中key自定义接口实现bean名称
rate-limiter: “#{@redisRateLimiter}” 默认可不用配置,如果有自定义实现,配置自定义实现的Bean名称
2、认证过程:
RedisRateLimiter调用isAllowed方法执行lua脚本并且返回剩余token-1个可

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值