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. 在路由列表点击创立按钮

APISIX限流实战

  1. 设置路由信息

APISIX限流实战

APISIX限流实战

  1. 设置上游服务 这里上游服务选咱们要转发的服务,比如order

APISIX限流实战

  1. 插件装备

限流相关的功能首要在插件里边。所以咱们需求选用限流的插件

APISIX限流实战

APISIX限流实战

总结

总的来说apisix供给的插件功能给我供给了十分丰富的扩展组件。咱们在对每个路由进行装备的时候只需求启动这些插件即可,十分简单

参考