nginx限速

基于nginx限速可以先参考下这篇文章:https://blog.csdn.net/hellow__world/article/details/78658041

基于openresty限速可以先参考下这篇文章:https://blog.csdn.net/cn_yaojin/article/details/81774380

 

下面贴出源站通过环境变量的方式直接设置openresty的QPS主要配置

    lua_shared_dict nginx_limit_req_store 10m;
    access_by_lua_block {
       local limit_req = require "resty.limit.req"

       local rate = tonumber(os.getenv("QPS"))
       if rate > 1000 then
           burst = rate - 1000
           rate = 1000
       else
           burst = rate / 2
           rate = rate / 2
       end
       local lim, err = limit_req.new("nginx_limit_req_store", rate, burst - 1)
       if not lim then
           ngx.log(ngx.ERR, "failed to instantiate a resty.limit.req object: ", err)
           return ngx.exit(500)
       end

 

踩坑记录:

1.rate参数是精确到ms,其最小单位是ms,但是最多可以限制请求1000r/s, 即1r/ms。设置再大,也不会是所想的2000r/s,也就是最多可以限制请求1000r/s。(通过测试得出)

2.burst是应对突发大量请求,以上配置,会瞬时提供处理(rate + burst)个请求的能力。

3.以上配置为什么rate和burst要中间换算一下?因为踩坑记录1所述。

posted @ 2021-06-02 22:27  Shadow.Yin  Views(140)  Comments(0Edit  收藏  举报