為了滿足網站高負荷的要求,在調整Apache參數時發現進程經常占用內存過多導致當機。經過不斷的優化和修改參數組合,終于讓服務器穩定 下來,可以滿足大量訪問的考驗和應用要求。筆者總結了調試過程中的問題和解決辦法如下,以供有類似需求的網管員參考(系統環境為Windows Server 2003和apache2.2.8):
1、http-mpm.conf設置
Apache的線程數控制文件為http-mpm.conf,在conf/exrtra目錄下面,要使該配置文件起作用需要在httpd.conf 中將 Include conf/extra/httpd-mpm.conf前#去掉,以使得http-mpm.conf生效。
在Windows系統中,起作用的是Winnt mpm段,
代碼如下:
<IfModule mpm_winnt_module>
ThreadsPerChild 150
MaxRequestsPerChild 0
</IfModule>
以上是缺省的配置,一般情況下夠用了,但負荷較大的網站就需要修改了,否則訪問網站會變慢或沒有響應。實際設置中可以根據apache-status查看apache實時連接狀態,查看其中線程占用數目情況來進行相應的調整,我的服務器最后設置如下:
代碼如下:
<IfModule mpm_winnt_module>
ThreadsPerChild 350
ThreadLimit 350
MaxRequestsPerChild 10000
</IfModule>
其中ThreadLimit是占用系統線程數限制,修改后會在apache-status中直接看到效果,就是對應的最大的可用線程數(如圖所示)。
MaxRequestsPerChild是進程的最大的請求數目,既指網站收到請求的緩存數。設置太小了會影響服務器性能,因為會占用較多cpu時 間,太大了則會占用內存資源。一般大型的網站文件個數都是成千上萬,所以管理員應該根據網站情況自己設定,只要不為0(無限制)就可以,以防止內存溢出。
ThreadsPerChlid是Apache進程的子線程數,意思是服務器開了這么多的線程數來等待響應客戶端請求。該參數需要根據 apache-status實時的監控情況來調節,太大會導致內存增長過快,直到服務器當機,太小會導致服務器連接隊列在高峰期時占滿,從而導致網站連接 慢。同時我們應該修改另一個配置文件httpd-default.php中的超時設置來配合這個參數。
2、httpd-default.conf設置
在httpd.conf中去掉Include conf/extra/httpd-default.conf前的#以使httpd-default.php生效。我們需要調節以下參數:
Timeout 15
該參數為連接超時,缺省的300秒顯然太大,縮小該參數就會減少同時連接數,即用戶實際占用的線程數,這樣就可以起到配合上面ThreadsPerChlid參數的作用。
KeepAlive On
該參數為是否保持活連接,目前網站中一個頁面一般會包含多個文件,所以相應用戶訪問時會有多個請求,因此開啟可以提高服務器性能。
MaxKeepAliveRequests 50
該參數為最大的活連接請求數,可以根據網頁實際包含的文件數目自行調節。
新聞熱點
疑難解答