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

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

Shell

1

2

3

4

5

6

7

8

9

10# httpd -V

Serverversion:Apache/2.4.10(Unix)

Serverbuilt:Dec29201411:23:13

Server'sModuleMagicNumber:20120211:36

Serverloaded:APR1.5.1,APR-UTIL1.5.3

Compiledusing:APR1.5.1,APR-UTIL1.5.3

Architecture:64-bit

ServerMPM:event

threaded:yes(fixedthreadcount)

forked:yes(variableprocesscount)

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

Shell

1--with-mpm=prefork|worker|event

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

Shell

1--enable-mpms-shared=all

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

Shell

1

2

3#LoadModule mpm_prefork_module modules/mod_mpm_prefork.so

LoadModulempm_worker_modulemodules/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中的配置方式:

Shell

1

2

3

4

5

6

7

StartServers5

MinSpareServers5

MaxSpareServers10

MaxRequestWorkers250

MaxConnectionsPerChild0

2. worker MPM

worker模式比起上一个,是使用了多进程和多线程的混合模式。它也预先fork了几个子进程(数量比较少),然后每个子进程创建一些线程,同时包括一个监听线程。每个请求过来,会被分配到1个线程来服务。线程比起进程会更轻量,因为线程通常会共享父进程的内存空间,因此,内存的占用会减少一些。在高并发的场景下,因为比起prefork有更多的可用线程,表现会更优秀一些。

有些人会觉得奇怪,那么这里为什么不完全使用多线程呢,还要引入多进程?

原因主要是需要考虑稳定性,如果一个线程异常挂了,会导致父进程连同其他正常的子线程都挂了(它们都是同一个进程下的)。为了防止这场异常场景出现,就不能全部使用线程,使用多个进程再加多线程,如果某个线程出现异常,受影响的只是Apache的一部分服务,而不是整个服务。

优点:占据更少的内存,高并发下表现更优秀。

缺点:必须考虑线程安全的问题,因为多个子线程是共享父进程的内存地址的。如果使用keep-alive的长连接方式,某个线程会一直被占据,也许中间几乎没有请求,需要一直等待到超时才会被释放。如果过多的线程,被这样占据,也会导致在高并发场景下的无服务线程可用。(该问题在prefork模式下,同样会发生)

注:keep-alive的长连接方式,是为了让下一次的socket通信复用之前创建的连接,从而,减少连接的创建和销毁的系统开销。保持连接,会让某个进程或者线程一直处于等待状态,即使没有数据过来。

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

1

2

3

4

5

6

7

8<IfModulempm_worker_module>

StartServers3

MinSpareThreads75

MaxSpareThreads250

ThreadsPerChild25

MaxRequestWorkers400

MaxConnectionsPerChild0

</IfModule>

3. event MPM

这个是Apache中最新的模式,在现在版本里的已经是稳定可用的模式。它和worker模式很像,最大的区别在于,它解决了keep-alive场景下,长期被占用的线程的资源浪费问题(某些线程因为被keep-alive,空挂在哪里等待,中间几乎没有请求过来,甚至等到超时)。event MPM中,会有一个专门的线程来管理这些keep-alive类型的线程,当有真实请求过来的时候,将请求传递给服务线程,执行完毕后,又允许它释放。这样增强了高并发场景下的请求处理能力。

event MPM在遇到某些不兼容的模块时,会失效,将会回退到worker模式,一个工作线程处理一个请求。官方自带的模块,全部是支持event MPM的。

注意一点,event MPM需要Linux系统(Linux 2.6+)对EPoll的支持,才能启用。

还有,需要补充的是HTTPS的连接(SSL),它的运行模式仍然是类似worker的方式,线程会被一直占用,知道连接关闭。部分比较老的资料里,说event MPM不支持SSL,那个说法是几年前的说法,现在已经支持了。

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

Shell

1

2

3

4

5

6

7

8

StartServers3

MinSpareThreads75

MaxSpareThreads250

ThreadsPerChild25

MaxRequestWorkers400

MaxConnectionsPerChild0

三种模式下,我通过ab做了一下性能测试,在常规满负载的场景下,并未发现有大的差异。

测试语句:

C

1./ab-k-c200-n200000192.168.0.11/index.html

测试结果:

C

1

2

3prefork:9556QPS

worker:11038QPS

event:10224QPS

测试语句:

C

1./ab-k-c200-n200000192.168.0.11/index.php(echo"hello world";)

测试结果:

C

1

2

3prefork:6094QPS

worker:7411QPS

event:7089QPS

就使用PHP而言,fastCGI和php-fpm是更推荐的使用模式。

现在的最新浏览器,在单个域名下的连接数变得越来越多(通常都是使用keep-alive),主流浏览器是2-6个(还有继续增长趋势,为了加快页面的并发下载速度)。高并发场景,会越来越成为Web系统的一种常态。Apache很成熟,同时也背负了比较重的历史代码和模块,因此,在Web系统比较方面,Nginx在不少场景下,表现比起Apache更为出色。

php apache mpm,Apache的三种MPM模式比较:prefork,worker,event相关推荐

  1. Apache Prefork、Worker和Event三种MPM分析

    三种MPM介绍 Apache 2.X 支持插入式并行处理模块,称为多路处理模块(MPM).在编译apache时必须选择也只能选择一个MPM,对类UNIX系统,有几个不同的MPM可供选择,它们会影响到a ...

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

    就最新版本的Web服务器Apache(版本是Apache 2.4.10,发布于2014年7月21日)来说,一共有三种稳定的MPM(Multi-Processing Module,多进程处理模块)模式. ...

  3. apache2.4.x三种MPM介绍

    三种MPM介绍                                                                               Apache 2.X  支持 ...

  4. 【转】Apache 配置虚拟主机三种方式

    Apache 配置虚拟主机三种方式 原文博客http://www.cnblogs.com/hi-bazinga/archive/2012/04/23/2466605.html 一.基于IP 1. 假设 ...

  5. 2021年大数据Hive(二):Hive的三种安装模式和MySQL搭配使用

    全网最详细的Hive文章系列,强烈建议收藏加关注! 后面更新文章都会列出历史文章目录,帮助大家回顾知识重点. 目录 系列历史文章 前言 Hive的三种安装模式和MySQL搭配使用 一.Hive的安装方 ...

  6. Nacos系列:Nacos的三种部署模式

    三种部署模式 Nacos支持三种部署模式 1.单机模式:可用于测试和单机使用,生产环境切忌使用单机模式(满足不了高可用) 2.集群模式:可用于生产环境,确保高可用 3.多集群模式:可用于多数据中心场景 ...

  7. Hadoop三种安装模式

    2019独角兽企业重金招聘Python工程师标准>>> Hadoop三种安装模式:单机模式,伪分布式,真正分布式 一 单机模式standalone 单机模式是Hadoop的默认模式. ...

  8. 【Tomcat】Tomcat Connector的三种运行模式【bio、nio、apr】

    Tomcat Connector(Tomcat连接器)有bio.nio.apr三种运行模式 bio bio(blocking I/O,阻塞式I/O操作),表示Tomcat使用的是传统的Java I/O ...

  9. Tomcat Connector的三种运行模式【bio、nio、apr】

    Tomcat Connector(Tomcat连接器)有bio.nio.apr三种运行模式 bio bio(blocking I/O,阻塞式I/O操作),表示Tomcat使用的是传统的Java I/O ...

  10. Nacos系列:Nacos的三种部署模式 1

    三种部署模式 Nacos支持三种部署模式 1.单机模式:可用于测试和单机使用,生产环境切忌使用单机模式(满足不了高可用) 2.集群模式:可用于生产环境,确保高可用 3.多集群模式:可用于多数据中心场景 ...

最新文章

  1. 设计模式——装饰者模式
  2. c4d fbx大小_【第77期】双节来临,全球顶级C4D商用模型助你一臂之力!
  3. php smarty 限制显示字数,smarty现在显示字数的各种写法
  4. JAVA自学笔记22
  5. 第一次用access的数据库是连接字符串问题
  6. JAVA面试题(20)
  7. poj2464扫描线好题,树状数组解法
  8. 计算机网络的ip分配,IP地址分配_网络设备技术应用_太平洋电脑网PConline
  9. Python 分离路径和文件名,分离文件名和后缀
  10. sklearn 使用joblib保存模型,并解决cannot import name joblib from sklearn.externals报错
  11. 团体程序设计天梯赛-练习集-L1-036. A乘以B
  12. 【转】iOS多线程编程技术之NSThread、Cocoa NSOperation、GCD
  13. Anbox之Ubuntu18.04安装(二)
  14. jeesit 可以用俩种导出
  15. IC卡(智能卡)APDU通讯总结
  16. 多维度分析评价体系:高校教学质量大数据应用解决方案
  17. wps序号打乱重新排序_wps序号怎么自动排列
  18. 毕业几年LINUX 驱动研发工作心得分享
  19. 力扣(707.面试题02.07)补9.16
  20. visualvm下载和安装

热门文章

  1. 支付宝支付出现 openssl_sign(): supplied key param cannot be coerced into a private key
  2. Swift learning part 18 - 类型转换
  3. python自动办公pdf_python自动化办公之 Python 解析 PDF
  4. Deepin20.5安装maven
  5. Axure软件的使用
  6. 泛在网、物联网与传感器网络有什么区别
  7. Kopernio插件+SCI-HUB最新可用网址
  8. python怎样输出字符串和数字_从零开始py个thon2:数字与字符串
  9. Tableau——其他参考方法
  10. STM32F401的PWM输出