nginx 限制ip併發數和限制速度
分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow
也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!
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/host/gaojinbo.com.conf
limit_conn one 10;
3.重啟nginx
killall -HUP 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。