相信專業,給你品質 專營建築物防水、抓漏、除壁癌、拆除工程 | 直接提供客戶給您,每天提供給您新客戶帶來新商機 不用再花高額的廣告費做些沒效果的廣告 |
apache防止 FlashGet/NetAnt 大量抓檔 |
房東:皮卡丘 發表時間:2007-02-17 |
如果你使用 apache 架設比較大的站台,通常都會遇到兇暴的使用者:用 FlashGet/NetAnt 或是其他類似軟體對站台大量抓檔。 我曾經在某些 IIS website 上面看過某個功能:只讓你有兩個連線可以抓檔 案,其他的會 queue 住。 我不清楚是不是 IIS 的功能,或是 firewall 的功能,但是我蠻欣賞這項功 能的,所以我開始在 apache 上尋找類似的 module。 在 http://dominia.org/djao/limitipconn.html 提到的 mod_limitipconn 剛好就是我要的功能,所以我把他做成 ports (感謝 ijliao commit),目前 我已經在某台機器上跑起來,效果看起來還不錯。 * 要求 apache13 系列 (apache13、apache13-modssl、...)。 limitipconn 0.04 版 *不支援* apache2,但作者已經在 limitipconn 0.22 版支援 apache2,不過我這邊測不出來。 * 安裝 請先將 ports 更新。如果您不知道如何更新 ports,請參考我寫的另外一篇 文章: http://ccca.nctu.edu.tw/~gslin/Documents/FreeBSD/use-cvsup.txt 更新完 ports 後,請打入下面的指令: cd /usr/ports/www/mod_limitipconn make all install clean * 設定 安裝完以後,請到 /usr/local/etc/apache/httpd.conf 內將下面三行最前 面的 '#' 拿掉。 也就是說,分別將下面三行: #LoadModule limitipconn_module libexec/apache/mod_limitipconn.so #AddModule mod_limitipconn.c #ExtendedStatus On 改成下面三行: LoadModule limitipconn_module libexec/apache/mod_limitipconn.so AddModule mod_limitipconn.c ExtendedStatus On 然後新增這部分: MaxConnPerIP 5 MaxConnPerIP 2 這個部分應該很好理解,您可以參考原網站的 README 給的範例來設定: http://dominia.org/djao/limitipconn-README Okay,到這裡就設定完成了。 * 啟動! 請下下面的指令,先檢查看看設定檔有沒有錯誤: apachectl configtest 如果沒有錯誤,那麼就用下面的指令讓 apache 重新啟動吧: apachectl restart |
|
廣利不動產-板橋在地生根最實在--新板特區指名度最高、值得您信賴的好房仲 完整房訊,房屋、店面熱門精選物件,廣利不動產 優質仲介,房屋租賃、買賣資訊透明,交易真安心! 廣利不動產-新板特區指名度最高、值得您信賴的好房仲 您的托付,廣利用心為您服務 |
1 樓住戶:龍龍 發表時間:2007-02-17 |
Apache mod_limitipconn http://dominia.org/djao/limitipconn.html 這個 mod 可以用來檔 flashget, net transport, netants 之類的多線程下載程式, 開太多線, 對 server 造成負擔, 又不會比較快 FreeBSD cd /usr/ports/www/mod_limitipconn && make install 編輯 httpd.conf LoadModule limitipconn_module libexec/apache/mod_limitipconn.so AddModule mod_limitipconn.c ExtendedStatus On 新增 MaxConnPerIP 2 MaxConnPerIP 2 若有 VirtualHost, 請加到對應的 block apachectl restart 後, 測試一下 log 裡面會發現 503, 就是被限制的線程 220.130.142.100 - - [20/Aug/2004:01:32:43 +0800] "GET /test.rar HTTP/1.1" 503 395 220.130.142.100 - - [20/Aug/2004:01:32:49 +0800] "GET /test.rar HTTP/1.1" 503 395 220.130.142.100 - - [20/Aug/2004:01:32:55 +0800] "GET /test.rar HTTP/1.1" 503 395 220.130.142.100 - - [20/Aug/2004:01:33:02 +0800] "GET /test.rar HTTP/1.1" 503 395 220.130.142.100 - - [20/Aug/2004:01:33:08 +0800] "GET /test.rar HTTP/1.1" 503 395 220.130.142.100 - - [20/Aug/2004:01:33:14 +0800] "GET /test.rar HTTP/1.1" 503 395 |
姓名: | |||
佈告內容: | |||
其他選項: | |||
|