Apache 两种mpm prefork 和 worker 的区别

Posted 日拱一卒,功不唐捐

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Apache 两种mpm prefork 和 worker 的区别相关的知识,希望对你有一定的参考价值。

  Apache默认的是线程安全的prefork,Prefork MPM 使用多个子进程,每个子进程有一个线程,每个进程每次只处理一个请求连接,一个请求出故障后不会影响其他请求,是线程安全的

  worker使用的是多进程多线程,每个进程有多个线程,每个线程每次处理一个请求连接,拥有更高的性能,但是是非线程安全的。

  php的官方推荐不适用线程的 mpm,即threaded MPM,因为PHP作为一种胶水语言,将几十种第三方库连接起来构建程序,如果其中有第三方库不能正常工作了,PHP都需要对其进行诊断问题然后修复,当底层的环境不是每个独立的进程和完全分离的内存分布的时候,将会带入很多不稳定因素进来。

  如果需要处理大量请求的话,可以将Apache + mod_php换成nginx + php-fpm。

 

http://httpd.apache.org/docs/2.2/mpm.html

http://www.nowamagic.net/librarys/veda/detail/1319/

以上是关于Apache 两种mpm prefork 和 worker 的区别的主要内容,如果未能解决你的问题,请参考以下文章

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

判断apache的工作模式是prefork模式还是worker模式

Apache三种MPM分析: PreforkWorker和Event

如何在apache中设置每个连接的最大请求数

如何设置Apache中的最大连接数

Apache的prefork模式和worker模式