Apache 的工作模式

Apache 是一个非常成熟的Web服务器,工作模式也在不断优化

现在 Apache 已经有了 3 个核心工作模式,看下他们各自的工作方式是什么样的

(1)prefork MPM,多进程工作模式

先生成主进程,完成基础的初始化工作,然后,通过fork预先产生一批的子进程(子进程会复制父进程的内存空间,不需要再做基础的初始化工作),然后等待服务

之所以预先生成,是为了减少频繁创建和销毁进程的开销

多进程的好处,是进程之间的内存数据不会相互干扰,同时,某个进程异常终止也不会影响其他进程。但是,就内存而言,每个子进程占用了很多的内存,因为子进程的内存数据是复制父进程的

存在大量的“重复数据”被放在内存中。最终,导致我们能够生成的子进程最大数量是很有限

在面对高并发时,因为有不少Keep-alive的长连接,将这些子进程“霸占”住,很可能导致可用子进程耗尽。因此,prefork并不太适合高并发场景

(2)worker MPM,多进程和多线程的混合模式

使用了多进程和多线程的混合模式,它也预先fork了几个子进程(数量很少),然后每个子进程创建一些线程

每个请求过来,会被分配到1个线程来服务,线程共享父进程的内存空间,因此,内存的占用会减少一些,在高并发的场景下,比起prefork更省内存

但是,它并没有解决Keep-alive的长连接“霸占”线程的问题,只是对象变成了比较轻量的线程。

使用进程和线程混合模式,是因为要考虑稳定性,如果一个线程挂了,会导致同一个进程下其他子线程都挂了,如果全部采用多线程,某个线程挂掉,就会影响整个Apache服务

线程共享父进程的内存空间,减少了内存的占用,却又引起了新的问题,就是“线程安全”,多个线程修改共享资源导致的“竞争行为”,因此,一定程度上增加Web服务的不稳定性

(3)event MPM,多进程和多线程的混合模式,引入Epoll

比较新的模式,2.4以后已经是稳定可用的模式,它和worker模式很像,最大的区别在于,它解决了keep-alive场景下,长期被占用的线程的资源浪费问题

event MPM中,会有一个专门的线程来管理这些keep-alive类型的线程,当有真实请求过来的时候,将请求传递给服务线程,执行完毕后,又允许它释放,它 减少了“占据”连接而又不使用的资源浪费,增强了高并发场景下的请求处理能力。因为减少了“闲等”的线程,线程的数量减少,同等场景下,内存占用会下降一 些。

Apache的三种模式中在真实应用场景中,event MPM是最节约内存的

原文发布于微信公众号 - 性能与架构(yogoup)

原文发表时间:2015-10-01

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏大前端开发

从编程小白到全栈开发:从最容易的开始

学习编程,重要的一点就是要进行思考,而更重要的一点是进行动手实践。简单的代码逻辑,我们可能想想就能在脑子里建立出这个代码的样子来,但是别以为你能永远这样人肉运行...

10730
来自专栏PHP在线

web缓存的作用和类型

前言&摘要 这段时间的工作内容主要是为一个客户端类型的产品增加文档在线存储和文档在线预览相关特性。由于测试的同事比较细心和专业,发现了项目实现中一些效 率低下的...

36350
来自专栏高性能服务器开发

关于即时通信服务器架构的一些思考

对于一个即时通信服务器来说,在用户量少的时候,一台服务器就足以提供所有的服务。而这种架构也最简单,举个例子,用户A与用户B互为好友,A向B发消息,服务器接收到消...

31450
来自专栏北京马哥教育

SQLAlchemy基本使用

云豆贴心提醒,本文阅读时间6分钟,文末有秘密! ORM介绍 ORM(Object-Relational Mapping) 架构,采用元数据来描述对象-关系映射...

40670
来自专栏云计算教程系列

如何使用ntopng监控您的网络

ntop 是最好的网络监控工具之一。ntop是一个网络探测器,它以与top显示进程般类似的方式显示网络使用率。在交互模式中,它显示了用户终端上的网络状态。在网页...

63140
来自专栏java思维导图

后端架构高可用可伸缩

考虑一个问题,两台机器,两个公网IP,DNS把域名同时定位到两个IP,这算高可用吗

14720
来自专栏

即时通信服务器架构的一些思考

对于一个即时通信服务器来说,在用户量少的时候,一台服务器就足以提供所有的服务。而这种架构也最简单,举个例子,用户A与用户B互为好友,A向B发消息,服务器接收到消...

25650
来自专栏蘑菇先生的技术笔记

Redis高可用分布式内部交流(九)

37570
来自专栏北京马哥教育

大神教你DIY高性能运维堡垒体系

概述 不怕出问题,就怕出问题找不到原因 运维团队一般会有个需求就是记录运维或者开发同事在服务器上的操作记录,比如进行一些常规审核或者是服务器被黑了、服务器日志被...

50560
来自专栏Golang语言社区

由Go语言并发模型想到游戏服务器并发

这段时间看了一些Go语言相关的东西,发现Go语言的最大特性并发模型类似于C++里面的线程池,正好我们项目服务器也是用的线程池,记录下。   Go语言的并发单位是...

45580

扫码关注云+社区

领取腾讯云代金券