APISIX限流实战

apisix限流算法

目前apisix主要提供三种限流方式

Limit-req(漏桶算法)

漏桶算法限制单个客户端对服务的请求速率

目前看到的漏桶算法只支持单机限流, 所以线上不推荐使用limit-req

limit-count

对单个服务的并发请求数。当客户端对路由的并发请求数达到限制时。

这个主要是基于客户端连接数的,也是仅支持单机

limit-count

使用固定时间窗口算法,主要用于限制单个客户端在指定的时间范围内对服务的总请求数,并且会在 HTTP 响应头中返回剩余可以请求的个数 该限流方式支持外接redis来支持集群限流。但是固定时间窗口算法有一个致命的缺点我们需要注意 比如时间窗口设置为1,qps设置为200.

在 0-0.5请求为0, 0.5 -1s访问量为200 在 1-1.5访问量为200。

这种情况并不会限流。因为不是滑动窗口。

但是实际在0.5-1.5这1s内的请求数量是400

实战

  1. 在路由列表点击创建按钮
  1. 设置路由信息
  1. 设置上游服务 这里上游服务选我们要转发的服务,比如order
  1. 插件配置

限流相关的功能主要在插件里面。所以我们需要选用限流的插件

总结

总的来说apisix提供的插件功能给我提供了非常丰富的扩展组件。我们在对每个路由进行配置的时候只需要启动这些插件即可,非常简单

参考

相关推荐
woniu_maggie1 分钟前
SAP冲销凭证功能
后端
一念之间lq2 分钟前
Elpis 第三阶段· 领域模型架构建设
前端·后端
+VX:Fegn089513 分钟前
计算机毕业设计|基于springboot + vue旅游信息推荐系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计·旅游
码界奇点20 分钟前
基于SpringBoot和Vue的Fuint门店会员营销系统设计与实现
vue.js·spring boot·后端·毕业设计·springboot·源代码管理
用户99045017780091 小时前
ruoyi-vue2集成DMN规则引擎实现Dish出餐决策
后端
IT_陈寒1 小时前
SpringBoot 3.2 实战:用这5个新特性让你的API性能提升40%
前端·人工智能·后端
五仁火烧1 小时前
安装rust开发环境
开发语言·后端·rust
IT枫斗者2 小时前
Netty的原理和springboot项目整合
java·spring boot·后端·sql·科技·mysql·spring
Java程序之猿2 小时前
Springboot 集成apache-camel +mqtt 根据主题处理mqtt消息
java·spring boot·后端
serendipity_hky2 小时前
【go语言 | 第3篇】go中类的封装、继承、多态 + 反射
开发语言·后端·golang·反射