Apache HTTP Server 版本2.2
Apache MPM prefork
说明 | 一个非线程型的、预派生的MPM |
---|---|
状态 | MPM |
模块名 | mpm_prefork_module |
源文件 | prefork.c |
概述
这个多路处理模块(MPM)实现了一个非线程型的、预派生的web服务器,它的工作方式类似于Apache 1.3。它适合于没有线程安全库,需要避免线程兼容性问题的系统。它是要求将每个请求相互独立的情况下最好的MPM,这样若一个请求出现问题就不会影响到其他请求。
这个MPM具有很强的自我调节能力,只需要很少的配置指令调整。最重要的是将MaxClients
设置为一个足够大的数值以处理潜在的请求高峰,同时又不能太大,以致需要使用的内存超出物理内存的大小。
工作方式
一个单独的控制进程(父进程)负责产生子进程,这些子进程用于监听请求并作出应答。Apache总是试图保持一些备用的(spare)或者是空闲的子进程用于迎接即将到来的请求。这样客户端就不需要在得到服务前等候子进程的产生。
StartServers
, MinSpareServers
, MaxSpareServers
, MaxClients
指令用于调节父进程如何产生子进程。通常情况下Apache具有很强的自我调节能力,所以一般的网站不需要调整这些指令的默认值。可能需要处理最大超过256个并发请求的服务器可能需要增加MaxClients
的值。内存比较小的机器则需要减少MaxClients
的值以保证服务器不会崩溃。更多关于调整进程产生的问题请参见性能方面的提示。
在Unix系统中,父进程通常以root
身份运行以便邦定80端口,而Apache产生的子进程通常以一个低特权的用户运行。User
和Group
指令用于设置子进程的低特权用户。运行子进程的用户必须要对它所服务的内容有读取的权限,但是对服务内容之外的其他资源必须拥有尽可能少的权限。
MaxRequestsPerChild
指令控制服务器杀死旧进程产生新进程的频率。
MaxSpareServers 指令
说明 | 空闲子进程的最大数量 |
---|---|
语法 | MaxSpareServers number |
默认值 | MaxSpareServers 10 |
作用域 | server config |
状态 | MPM |
模块 | prefork |
MaxSpareServers
指令设置空闲子进程的最大数量。所谓空闲子进程是指没有正在处理请求的子进程。如果当前有超过MaxSpareServers
数量的空闲子进程,那么父进程将杀死多余的子进程。
只有在非常繁忙机器上才需要调整这个参数。将此参数设的太大通常是一个坏主意。如果你将该指令的值设置为比MinSpareServers
小,Apache将会自动将其修改成"MinSpareServers
+1
"。