nginx限速

2021/6/3 7:21:09

本文主要是介绍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所述。



这篇关于nginx限速的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程