首页 存档 技术 查看内容

Apache的三种MPM模式比较:prefork,worker,event

2018-3-30 13:00 |来自: 互联网 444 0

摘要: (点击上方公众号,可快速关注) 作者:伯乐在线 - 徐汉彬 网址:http://blog.jobbole.com/91920/ 就最新版本的Web服务器Apache(版本是Apache 2.4.10,发布于2014年7月21日)来说,一共有三种稳定的MPM(Multi-Pr ...

(点击上方公众号,可快速关注)


作者:伯乐在线 - 徐汉彬

网址:http://blog.jobbole.com/91920/

就最新版本的Web服务器Apache(版本是Apache 2.4.10,发布于2014年7月21日)来说,一共有三种稳定的MPM(Multi-Processing Module,多进程处理模块)模式。它们分别是prefork,worker和event,它们同时也代表这Apache的演变和发展。

查看我们Apache的模式,可以使用httpd -V命令来查看:

# httpd -V

Server version: Apache/2.4.10 (Unix)

Server built: Dec 29 2014 11:23:13

Server's Module Magic Number: 20120211:36

Server loaded: APR 1.5.1, APR-UTIL 1.5.3

Compiled using: APR 1.5.1, APR-UTIL 1.5.3

Architecture: 64-bit

Server MPM: event

threaded: yes (fixed thread count)

forked: yes (variable process count)

编译的时候,可以通过configure的参数来指定:

--with-mpm=prefork|worker|event

也可以编译为三种都支持,通过修改配置来更换

--enable-mpms-shared=all

在httpd.conf中修改Apache的多处理模式MPM可以通过(modules文件夹下,会自动编译出三个MPM的so):

#LoadModule mpm_prefork_module modules/mod_mpm_prefork.so

LoadModule mpm_worker_module modules/mod_mpm_worker.so

#LoadModule mpm_event_module modules/mod_mpm_event.so

1. prefork MPM

prefork模式可以算是很古老但是非常稳定的Apache模式。Apache在启动之初,就预先fork一些子进程,然后等待请求进来。之所以这样做,是为了减少频繁创建和销毁进程的开销。每个子进程只有一个线程,在一个时间点内,只能处理一个请求。

优点:成熟稳定,兼容所有新老模块。同时,不需要担心线程安全的问题。(我们常用的mod_php,PHP的拓展不需要支持线程安全)

缺点:一个进程相对占用更多的系统资源,消耗更多的内存。而且,它并不擅长处理高并发请求,在这种场景下,它会将请求放进队列中,一直等到有可用进程,请求才会被处理。

Apache的httpd.conf中的配置方式:

声明:文章版权归原作者所有 部分文章转自互联网 如有侵权请联系 [邮箱地址] 删除

路过

雷人

握手

鲜花

鸡蛋

相关分类

返回顶部