【Nginx】限流配置

废话不多说,直接上配置文件

http {
    include       mime.types;
    default_type  application/octet-stream;

    #1、限流设置
    limit_req_zone $binary_remote_addr zone=contentRateLimit:10m rate=2r/s;

    #2、根据IP地址来限制,存储内存大小10M
    limit_conn_zone $binary_remote_addr zone=addr:1m;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       80;
        server_name  localhost;
        location /{
            #3、表示同一个地址只允许连接2次
            limit_conn addr 2;
            proxy_pass http://ip:port;
        }
    }
}

代码中的123,分别配置上去,然后重启nginx,测试一下对应接口是否会有限流


上面的代码中,限制的连接数是2,如果使用Jmeter制造>2的并发,那就会报错了,所以接下来需要限制每个客户端的ip与服务器的连接数,同时限制与虚拟服务器的连接总数

http {
    include       mime.types;
    default_type  application/octet-stream;
    #1
    limit_conn_zone $binary_remote_addr zone=perip:10m;
    #2
    limit_conn_zone $server_name zone=perserver:10m; 

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       80;
        server_name  localhost;
        location /{
            #3
            limit_conn perip 10;#单个客户端ip与服务器的连接数.
            #4
            limit_conn perserver 100; #限制与服务器的总连接数
            proxy_pass http://ip:port;
        }
    }
}

代码中的1234配置上去即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值