高负载下 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 计算出
相关文章
相关标签/搜索