Skip to content

Instantly share code, notes, and snippets.

@njujerry
Created April 19, 2017 03:48
Show Gist options
  • Save njujerry/2da850b8777bf5f082e13a83bd94ab43 to your computer and use it in GitHub Desktop.
Save njujerry/2da850b8777bf5f082e13a83bd94ab43 to your computer and use it in GitHub Desktop.
Apche的httpd-mpm.conf配置

Apche的httpd-mpm.conf配置

mpm:多路处理模块

首先确定apache是使用哪种工作模式,是prefork模式还是worker模式,查看方法 apachectl -l
查看后显示 会出现各种模块的名称,找是否有prefork或者worker之类的mpm模式名 看到红色加粗部分,显示 prefork ,所以是prefork模式。

那么httpd-mpm.conf 中就该配置 # prefork MPM 部分了,prefork模式的默认配置是:

<IfModule mpm_prefork_module>
                StartServers                      5
                MinSpareServers                   5
                MaxSpareServers                  10
                MaxClients                      150
                MaxRequestsPerChild               0
</IfModule>

如何去评估这些参数呢?先来看看各个参数的含义。 prefork 模式的工作原理大概为: 控制进程在最初建立StartServers个子进程后, 为了满足MinSpareServers设置的需要,创建一个进程,等待一秒钟,继续创建第二个,等待一秒钟,继而创建四个(2的平方),如此按指数级增加创建的进程 数,最多达到每秒32个,直到满足MinSpareServers设置的值为止,这也就是预派生(prefork)的由来。这种模式可以使得不必在请求到 来时再产生新的进程,从而减小了系统开销以增加性能。

MaxSpareServers 设置了最大的空闲进程数,如果空闲进程数大于这个值,Apache会自动kill某些多余进程。这个值一般不要设的过大,但如果设的比 MinSpareServers小,Apache会自动把它调整为MinSpareServers+1。如果站点负载较大的话,可考虑同时加大 MinSpareServers和MaxSpareServers。 MaxRequestsPerChild设置的是每个子进程可以 处理的请求数。每个子进程在处理了MaxRequestsPerChild个请求后将自动销毁。0意味着无限,即子进程永不销毁。虽然缺省设为0可以使每 个子进程处理更多的请求,但如果设成非零值也有两点重要的好处:

1. 可防止意外的内存卸漏;
2. 在服务器负载下降的时侯会自动减少子进程数。

因此,可根据服务器的负载来调整这个值,如果非零的话,笔者认为10000左右是比较合适的。事实上这个值对Apache的性能影响不是很大。 MaxClients 是这些指令中最为重要的一个,它设定的就是Apache可以同时处理的请求,这是对Apache性能影响最大的参数.在我个人看来,缺省的150是远远不 够的,如果请求总数已达到这个值(可通过ps –ef|grep httpd|wc –l来确认),那么下面的请求就要排队,直到某个已处理请求完毕。这就是为什么系统资源还剩下很多,而http访问却很慢的主要原因。系统管理员可以根据硬件配置和负载情况来动态调整这个值,虽然理论上这个值越大,可以处理的请求就越多,但实际上,平时根据咱们用的服务器(比如戴尔2950)配置,这个参数设置到500已经足够。注意的是,在Apache1版本中,这个参数是有限制的,不能超过256,即使你设置大于256也不管用,除非更改源代码重新编译。在Apache2.0中新加入了ServerLimit指令,使得无须重编译Apache就可以加大MaxClients。

下面是笔者的prefork配置段。

<IfModule mpm_prefork_module>
    ServerLimit        2048
    StartServers        10
    MinSpareServers       10
    MaxSpareServers      15
    MaxClients         500
    MaxRequestsPerChild  10000
</IfModule>

关于mpm中的MaxRequestPerChild

通常在“Windows任务管理器-进程”中可以看到两个apache.exe进程,一个是父进程、一个是子进程,父进程接到访问请求 后,将请求交由子进程处理。 MaxRequestsPerChild这个指令设定一个独立的子进程将能处理的请求数量。在处理 “MaxRequestsPerChild 数字”个请求之后,子进程将会被父进程终止,这时候子进程占用的内存就会释放,如果再有访问请求,父进程会重新产生子进程进行处理。  

如果 MaxRequestsPerChild缺省设为0(无限)或较大的数字(例如10000以上)可以使每个子进程处理更多的请求,不会因为不断终止、启动子进程降低访问效率,但MaxRequestsPerChild设置为0时,如果占用了200~300M内存,即使负载下来时占用的内存也不会减少。内存 较大的服务器可以设置为0或较大的数字。内存较小的服务器不妨设置成30、50、100,以防内存溢出。

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment