博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
高并发API网关,Spring Cloud Gateway 之限流操作
阅读量:4068 次
发布时间:2019-05-25

本文共 1114 字,大约阅读时间需要 3 分钟。

高并发系统常用三板斧来保护系统:缓存降级限流,API网关作为所有请求的入口,请求量大,可以通过对并发访问的请求进行限速来保护系统的可用性。

高并发API网关,Spring Cloud Gateway 之限流操作

 

常用的限流算法比如有令牌桶算法,漏桶算法,计数器算法等,在Zuul中我们可以自己去实现限流的功能,Spring Cloud Gateway的出现本身就是用来替代Zuul的,要想替代那肯定得有强大的功能,除了性能上的优势之外,Spring Cloud Gateway还提供了很多新功能,比如限流操作,使用起来非常简单。

高并发API网关,Spring Cloud Gateway 之限流操作

 

目前限流提供了基于Redis的实现,首先引入依赖,

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

然后就可以以通过KeyResolver来指定限流的Key,比如我们需要根据用户来做限流,IP来做限流等等。

一、IP限流

通过exchange对象可以获取到请求信息,这边用了HostName。

@BeanKeyResolver userKeyResolver() {	return exchange -> Mono.just(exchange.getRequest().getQueryParams().getFirst("userId"));}

二、用户限流

通过exchange对象可以获取到请求信息,获取当前请求的用户ID或者用户名,使用这种方式限流,请求路径中必须携带userId参数。

@BeanKeyResolver userKeyResolver() {	return exchange -> Mono.just(exchange.getRequest().getQueryParams().getFirst("userId"));}

三、接口限流

获取请求地址的uri作为限流key。

@BeanKeyResolver apiKeyResolver() {	return exchange -> Mono.just(exchange.getRequest().getPath().value());}

四、配置过滤器

高并发API网关,Spring Cloud Gateway 之限流操作

 

  • filter名称必须是RequestRateLimiter
  • redis-rate-limiter.replenishRate:允许用户每秒处理多少个请求
  • redis-rate-limiter.burstCapacity:令牌桶的容量,允许在一秒钟内完成的最大请求数
  • key-resolver:使用SpEL按名称引用bean

高并发API网关,Spring Cloud Gateway 之限流操作

 

配置好后就可以进行限流测试了,注意观察redis中的数据。

转载地址:http://emoji.baihongyu.com/

你可能感兴趣的文章
Homebrew指令集
查看>>
React Native(一):搭建开发环境、出Hello World
查看>>
React Native(二):属性、状态
查看>>
JSX使用总结
查看>>
React Native(四):布局(使用Flexbox)
查看>>
React Native(七):Android双击Back键退出应用
查看>>
Android自定义apk名称、版本号自增
查看>>
adb command not found
查看>>
Xcode 启动页面禁用和显示
查看>>
【剑指offer】q50:树中结点的最近祖先
查看>>
二叉树的非递归遍历
查看>>
【leetcode】Reorder List (python)
查看>>
【leetcode】Linked List Cycle (python)
查看>>
【leetcode】Linked List Cycle (python)
查看>>
【leetcode】Candy(python)
查看>>
【leetcode】Sum Root to leaf Numbers
查看>>
【leetcode】Pascal's Triangle II (python)
查看>>
java自定义容器排序的两种方法
查看>>
如何成为编程高手
查看>>
本科生的编程水平到底有多高
查看>>