Tengine 限制连接数和白名单功能

本文介绍了一种使用Nginx进行限流的具体配置方案,包括如何设置连接数限制和请求速率限制,并通过白名单机制对特定IP进行豁免。此外还详细展示了不同目录及文件类型的限流策略。

tenginx1.4.2 version

nginx.conf

  limit_conn_zone $binary_remote_addr zone=conn_limit_per_ip:10m;
  limit_req_zone $binary_remote_addr zone=req_limit_per_ip:10m rate=1r/s;
geo $white_ip  {
    ranges;
    default        0;
    60.126.39.182-60.126.39.184     1;
    58.112.221.179-58.112.221.190 1;
    141.130.163.153-141.130.163.154 1;
}
limit_req_whitelist geo_var_name=white_ip geo_var_value=1;
limit_req_zone $binary_remote_addr zone=white_ip:100m rate=1r/s;
include /usr/local/webserver/nginx/conf/vhosts/*.conf;
}

 

vhosts(控制下面几个php文件)

location   ~*^/(home|forum|portal|forum|forumdisplay|index).php$ {
 root /htdoc/bbs.123.com/wwwroot;
limit_conn conn_limit_per_ip 2;
    limit_req zone=white_ip  burst=3 nodelay;
limit_req_whitelist geo_var_name=white_ip geo_var_value=1;
 fastcgi_pass  127.0.0.1:9000;
      fastcgi_index index.php;
      include fcgi.conf;

}

 

        location ~ ^/html/ {   //控制这个目录下面的文件
    limit_req zone=white_ip  burst=4 nodelay;
limit_req_whitelist geo_var_name=white_ip geo_var_value=1;
}

 

 location   ~*^/(home|forum|message_check|test).php$ {     /*当前目录下的文件受限制*/

 root /ht/hf/old.123.com;

limit_conn conn_limit_per_ip 2;

    limit_req zone=white_ip  burst=2 nodelay;

limit_req_whitelist geo_var_name=white_ip geo_var_value=1;

 fastcgi_pass  127.0.0.1:9000;

      fastcgi_index index.php;

      include fcgi.conf;

}

location ~* ^/(chushou)/.*\.php$ {       /*chushou目录下的文件受限制*/

limit_conn conn_limit_per_ip 2;

    limit_req zone=white_ip  burst=2 nodelay;

limit_req_whitelist geo_var_name=white_ip geo_var_value=1;

 fastcgi_pass  127.0.0.1:9000;

      fastcgi_index index.php;

      include fcgi.conf;

}

(感谢淘叔度指点)

白名单内的ip不受limit限制。



本文转自 liang3391 51CTO博客,原文链接:http://blog.51cto.com/liang3391/1004566

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值