Nginx帶寬控制(限速模塊使用)
有個老項(xiàng)目,通過 Squid 提供文件下載功能,利用 delay_parameters 實(shí)現(xiàn)帶寬控制,問題是我玩不轉(zhuǎn) Squid,于是盤算著是不是能在 Nginx 里找到類似的功能。
好消息是 Nginx 提供了 limit_rate 和limit_rate_after,舉個例子來說明一下:
location /download/ {
limit_rate_after 500k;
limit_rate 50k;
}
大概意思是:用戶下載達(dá)到 500k 后,便控制其速度在 50k 以內(nèi)。
壞消息是此控制是針對單個連接而言的。換言之,只能限制單個連接的帶寬,不能限制總帶寬。不過使用limit_conn 模塊的話,可以在一定程度上緩解問題:
limit_conn_zone $server_name zone=servers:10m;
server {
location /download/ {
limit_conn servers 1000;
limit_rate_after 500k;
limit_rate 50k;
}
}
通過 limit_conn 限制了并發(fā)連接數(shù),于是也就限制了總帶寬??上н@個解決方式并不完美,大家可以設(shè)想如下的例子:1000 個用戶能夠同時以 50k 的速度下載;那么在總帶寬不變的情況下,2000 個用戶是否能夠同時以 25k 的速度下載?從業(yè)務(wù)的角度看,答案自然是肯定的,可實(shí)際上 limit_conn 和 limit_rate 不夠靈活,無法簡單實(shí)現(xiàn)此類邏輯。
當(dāng)然,問題肯定有辦法解決。比如使用第三方模塊:limit_speed;還可以使用 Linux 內(nèi)置的 TC 命令。limit_speed 比較簡單,不多說了,接下來我們就看看 TC 的用法吧:
shell> tc qdisc add dev eth0 root handle 1: htb default 10
shell> tc class add dev eth0 parent 1: classid 1:1 htb rate 10mbit
shell> tc filter add dev eth0 protocol ip parent 1:0 prio 1 \
u32 match ip dport 80 0xffff flowid 1:1
TC 復(fù)雜的讓人發(fā)瘋,請參考:Linux Advanced Routing & Traffic Control HOWTO。
本文介紹了多個 Nginx 限制訪問方面的模塊,實(shí)際上還有一個 limit_req 模塊也超贊,雖然和本文關(guān)系不大,但建議大家了解,具體可以參考「nginx limit_req限速設(shè)置」。
相關(guān)文章
centos系統(tǒng)下LNMP環(huán)境一鍵安裝
centos下的LNMP環(huán)境一鍵安裝實(shí)現(xiàn)方法,需要的朋友可以參考下。2010-06-06
安裝配置php-fpm來搭建Nginx+PHP的生產(chǎn)環(huán)境
這篇文章主要介紹了安裝配置php-fpm來搭建Nginx+PHP的生產(chǎn)環(huán)境的方法,php-fpm的作用是將FastCGI進(jìn)程管理整合進(jìn)PHP包,需要的朋友可以參考下2016-01-01
Nginx 根據(jù)URL帶的參數(shù)轉(zhuǎn)發(fā)的實(shí)現(xiàn)
這篇文章主要介紹了Nginx 根據(jù)URL帶的參數(shù)轉(zhuǎn)發(fā)的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
nginx中g(shù)zip_types匹配content-type的方式
這篇文章主要介紹了nginx中g(shù)zip_types匹配content-type的方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05

