当前位置: > Linux服务器 > nginx >

Nginx限制ip并发数和限制下载速度

时间:2014-04-18 15:21来源:linux.it.net.cn 作者:IT网

1.添加limit_zone
这个变量只能在http使用

 

1
2
vi /usr/local/nginx/conf/nginx.conf 
limit_zone one $remote_addr 10m;

2.添加limit_conn
这个变量可以在http, server, location使用
我只限制一个站点,所以添加到server里面

1
2
vi /usr/local/nginx/conf/host/gaojinbo.com.conf 
limit_conn   one 10;

3.重启nginx

 

1
killall -HUP nginx

nginx 限速模块参考:

关于limit_zone:http://wiki.nginx.org/NginxHttpLimitZoneModule 关于limit_rate和limit_conn:http://wiki.nginx.org/NginxHttpCoreModule nginx可以通过HTTPLimitZoneModule和HTTPCoreModule两个组件来对目录进行限速。

1
2
3
4
5
6
7
8
9
http { 
  limit_zone   one  $binary_remote_addr  10m;  
  server { 
    location /download/
      limit_conn   one  1; 
      limit_rate 300k; 
    
  
}

limit_zone,是针对每个IP定义一个存储session状态的容器。这个示例中定义了一个10m的容器,按照32bytes/session,可以处理320000个session。

1
limit_conn one 1;

限制每个IP只能发起一个并发连接。

 

是指定向客户端传输数据的速度,单位是每秒传输的字节数

该限制只针对一个连接的设定,如果同时两个连接数,那么速度是设置值的两倍

 

1
2
limit_rate_after 3M;
limit_rate 300k;

对每个连接限速300k. 注意,这里是对连接限速,而不是对IP限速。如果一个IP允许两个并发连接,那么这个IP就是限速limit_rate×2。

 

 

当一个客户端连接后,将以最快的速度下载多大文件,然后在以限制速度下载文件

  limit_rate_after 该指令是下载字节量的大小值,而不是时间值

作用范围:http,server,location,if inlocation

(责任编辑:IT)
------分隔线----------------------------
栏目列表
推荐内容