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