开发者社区> 问答> 正文

Nginx限流问题?

已解决

我在购买了阿里的ECS,在上面部署了Nginx和转发应用,但是现在因为业务需求,Nginx上想做相关的限流,请问怎么做呢,主要限制请求数。

展开
收起
1118468786264222 2021-07-25 16:38:42 819 0
1 条回答
写回答
取消 提交回答
  • 网络规划设计师、敏捷专家、CISP、ITSS服务经理、ACA全科目、ACP4项、ACE、CBP、CDSP、CZTP等。拥有 PRINCE2 Foundation/Practitioner、CCSK、ITIL、ISO27001、PMP等多项国际认证。 专利5+、期刊10+、知识产权师。核心期刊审稿人。
    采纳回答

    您好,Nginx的限流都是基于漏桶流算法,在Nginx中限流有3种限流场景。

    正常限制访问频率(正常流量)
    突发限制访问频率(突发流量)
    限制并发连接数
    
    

    1、正常限制访问频率(正常流量)

    限制一个用户发送的请求,我Nginx多久接收一个请求。

    Nginx中使用ngx_http_limit_req_module模块来限制的访问频率,限制的原理实质是基于漏桶算法原理来实现的。在nginx.conf配置文件中可以使用limit_req_zone命令及limit_req命令限制单个IP的请求处理频率。
    
        #定义限流维度,一个用户一分钟一个请求进来,多余的全部漏掉
        limit_req_zone $binary_remote_addr zone=one:10m rate=1r/m;
    
        #绑定限流维度
        server{
    
            location /tiger.html{
                limit_req zone=zone;    
                proxy_pass https://www.aliyun.com;
            }
    
        }
    
    1r/s代表1秒一个请求,1r/m一分钟接收一个请求, 如果Nginx这时还有别人的请求没有处理完,Nginx就会拒绝处理该用户请求。
    
    

    2、突发限制访问频率(突发流量)

    限制一个用户发送的请求,Nginx多久接收一个。

    上面的配置一定程度可以限制访问频率,但是也存在着一个问题:如果突发流量超出请求被拒绝处理,无法处理活动时候的突发流量,这时候应该如何进一步处理呢?

    Nginx提供burst参数结合nodelay参数可以解决流量突发的问题,可以设置能处理的超过设置的请求数外能额外处理的请求数。我们可以将之前的例子添加burst参数以及nodelay参数:

        #定义限流维度,一个用户一分钟一个请求进来,多余的全部漏掉
        limit_req_zone $binary_remote_addr zone=one:10m rate=1r/m;
    
        #绑定限流维度
        server{
    
            location /tiger.html{
                limit_req zone=zone burst=5 nodelay;
                proxy_pass https://www.aliyun.com;
            }
    
        }
    
    

    为什么就多了一个 burst=5 nodelay; 这个可以代表Nginx对于一个用户的请求会立即处理前五个,多余的就慢慢来落,没有其他用户的请求我就处理你的,有其他的请求的话我Nginx就漏掉不接受你的请求

    3、 限制并发连接数

    Nginx中的ngx_http_limit_conn_module模块提供了限制并发连接数的功能,可以使用limit_conn_zone指令以及limit_conn执行进行配置。接下来我们可以通过一个简单的例子来看下:

    http {
        limit_conn_zone $binary_remote_addr zone=myip:10m;
        limit_conn_zone $server_name zone=myServerName:10m;
        }
    
        server {
            location / {
                limit_conn myip 10;
                limit_conn myServerName 100;
                rewrite / http://www.aliyun.com permanent;
            }
        }
    
    

    上面配置了单个IP同时并发连接数最多只能10个连接,并且设置了整个虚拟服务器同时最大并发数最多只能100个链接。当然,只有当请求的header被服务器处理后,虚拟服务器的连接数才会计数。

    2021-07-25 16:53:05
    赞同 2 展开评论 打赏
问答标签:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
《Nginx 代理系统常用手册》 立即下载
CentOS Nginx PHP JAVA 多语言镜像使用手 立即下载
CentOS Nginx PHP JAVA多语言镜像使用手册 立即下载