Apache多路复用模块(MPMs)介绍分享

这篇文章主要介绍了Apache多路复用模块(MPMs)介绍,MPM,也叫多道处理模块(Multi Processing Module),关系到整个HTTP会话,本文就介绍它的相关知识,需要的朋友可以参考下

当整个世界都慢慢倾向于nginx的时候,如果你还在使用apache,那么你可能会用尽一切办法来保证速度。你也许会调整要加载的模块,使用Keepalive、摆弄内容协商模块(mod_negotiation,译注:从几个文档中选择一个最匹配客户端要求的文档)、FollowSymLinks指令(译注:允许在此目录中使用软链接)以及重写功能;你甚至可能还会投入更多硬件,并假装自己没有。然而,如果你运营的网站非常繁忙而不想因为内存的原因而导致网站崩溃,那么你就应该关注你所使用的MPM。

MPM,也叫多道处理模块(Multi Processing Module),关系到真个HTTP会话。从网络上的监听、请求进入到最重要的–如何处理子请求,这里我们讨论的是子进程及子线程。对于unix系统的机器来说Apache提供了3种MPM以供选择:; Prefork, Worker, and Event。同时,只对其他系统Apache也提供了许多其他种类的MPM,但是我们这里主要关注最常见的,可能也是你最想看到的(也是我最擅长的)。这些MPM处理Apache服务器用来接受、处理以及服务器HTTP请求过程中的进程和潜在线程。

从不严格的角度来看,进程是一个程序的实例。每个进程是完全自包含的,并且在地址空间、变量、内存等方面和其他进程是完全独立、隔离开来执行的。为了理解本文目的和内容,你可以思考一下下面这句话:5个Apache进程表示运行着5个不同的Apache实例。虽然这是相当值得警告的做法,但是这足以安全的记住本文的目的。

换句话说,一个线程被一个进程创建并拥有。一个进程可以有多个线程,这些线程并不是完全独立的。它们共享进程为它们分配的同一个状态以及地址空间。

总之,进程是程序的一个实例,它被用来告诉整个系统它的存在以及需要资源并且可以执行他自己的资源;线程只有被进程创建以后才能真正执行一些东西。因此,线程不需要发布自己而是由整个应用如进程来做,而且线程本质上使用更少的系统资源如内存。

Apache Prefork MPM

Prefork多处理模块是非线程的。它完全不使用线程,使用整个进程用来处理每个HTTP请求。当一个HTTP请求传入,假设是用来请求你加猫咪的图片,那么整个进程都会去该请求捆绑而且为这个人的请求负责。如果在同一时间有其他人来浏览你家猫咪的图片,那么另一个完全不同的进程会被使用。

Prefork在快速和稳定性方面很好。Prefork只有轻微的边缘响应时间,这是因为它不需要处理在它进程中的不同线程;同时在一个特定的请求发生错误的情况下它也是稳定的,因为整个进程只是由一个请求决定,而其他请求是由另外的进程来处理,所以其他请求不受影响。

Prefork也适用于如果你所使用的apache模块不能处理线程的情况。最常见的是mod_php模块(尽管它的最新努力方向是ZTS)。你可能在使用PHP以及/或者一些不能被Apache所处理的脚本时会遇到这个问题,但是有一些脚本除外如php-fpm。

但是,如果你需要处理大量的并发请求,这种方式会疯狂"吃掉"系统资源。请注意,每个进程都会作为一个完整的Apache实例来发布自己。这意味着它会加载所有模块,而且对每个请求来说都是一个完整的web服务器。如果请求数非常大,而由于协调器需要发布与请求数相同的进程来处理这些请求,这会很快迫使内存使用率达到极限。

Apache Worker MPM

Work多路复用模块会使用线程,它在高并发时在内存使用方面处理的很好。在多路复用模块中,需要的进程数较少,因为它不想Prefork那样需要为每个请求创建一个进程,Worker模式会在进程中创建线程,请求进入的连接通过一个进程中的不同线程来处理。Worker模式中,新的连接只需要等待空闲的线程即可,而不是像Prefork中那样需要等待空闲进程。

文章来源:http://www.iis7.com/b/ssyqdq/

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,820评论 6 515
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,648评论 3 399
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 168,324评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,714评论 1 297
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,724评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,328评论 1 310
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,897评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,804评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,345评论 1 318
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,431评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,561评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,238评论 5 350
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,928评论 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,417评论 0 24
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,528评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,983评论 3 376
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,573评论 2 359

推荐阅读更多精彩内容