在Nginx服務器上進行一些常規設置,來限制其并發數及會話空間等。
nginx限制ip并發數,也是說限制同一個ip同時連接服務器的數量
1,添加limit_zone
這個變量只能在http使用
代碼示例:
vi /usr/local/nginx/conf/nginx.conf
limit_zone one $remote_addr 10m;
2,添加limit_conn
這個變量可以在http, server, location使用
只限制一個站點,所以添加到server里面
vi /usr/local/nginx/conf/vhost/303i.com.conf
limit_conn one 10;
3,重啟nginx
nginx 限速模塊
參考:
關于limit_zone:http://wiki.nginx.org/NginxHttpLimitZoneModule
關于limit_rate和limit_conn:http://wiki.nginx.org/NginxHttpCoreModule
nginx可以通過HTTPLimitZoneModule和HTTPCoreModule兩個組件來對目錄進行限速。
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。
limit_conn one 1;
限制每個IP只能發起一個并發連接。
limit_rate 300k;
對每個連接限速300k。
注意,這里是對連接限速,而不是對IP限速。
如果一個IP允許兩個并發連接,那么這個IP就是限速limit_rate×2。