高負載下 Apache 內存與進程的最佳實踐

檢查 Apache 是否運行在 prefork 的工做模式

apachectl -V | grep MPM
httpd -V | grep MPM

Server MPM:     Prefork
 -D APACHE_MPM_DIR="server/mpm/prefork"

查看當前每一個進程所佔用的內存

top -bn 1 | grep httpd

 56961 apache    20   0  406m  49m  40m S  1.9  0.1   0:21.92 httpd
 56963 apache    20   0  406m  53m  44m S  1.9  0.1   0:20.45 httpd
 56967 apache    20   0  402m  52m  42m S  1.9  0.1   0:20.28 httpd
 56971 apache    20   0  404m  54m  44m S  1.9  0.1   0:21.18 httpd
 56974 apache    20   0  415m  55m  42m S  1.9  0.1   0:20.07 httpd

RES column 是 Apache process 使用的內存量,左起第六列。nginx

計算進程數

最大進程數 = Apache 所能消耗的內存總量 / 每一個進程消耗內存量apache

設定相關參數

<IfModule prefork.c>
StartServers                30%MaxClients
MinSpareServers               5%
MaxSpareServers                 10%
ServerLimit                 256
MaxClients                  200 = 10G/50M
MaxRequestsPerChild 10000
</IfModule>

restart

  • apache 實際會在這個框架內,再控制進程。好比負載不高時候,自動減小進程。
  • apache 規劃的關鍵在最大負載時候內存量,這一點和 nginx 不一樣
  • 經過最大內存量,計算出 MaxClients
  • 全部其餘值均根據 MaxClients 計算出
相關文章
相關標籤/搜索