首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 服务器 > Apache >

Apache的多处置模块MPM

2012-10-14 
Apache的多处理模块MPM本博文主要参数 Apache 2.2文档以及Apache模块开发指南Apache的整个运行可以分为两

Apache的多处理模块MPM

本博文主要参数 Apache 2.2文档以及Apache模块开发指南


Apache的整个运行可以分为两个阶段:启动阶段和运行阶段。

       在启动阶段时,它以ROOT特权来启动,进行解析配置文件(一般就是httpd.conf)、加载模块和初始化一些日志文件及内存共享段等操作,在启动阶段准备结束时,apache的控制转向多处理模块MPM,此时使得MPM能够在系统特权级运行,从而管理接下来的运行阶段。因为当处于运行阶段时,程序会放弃ROOT特权,以接收并处理网络中用户的服务请求,所以MPM也是在启动阶段初始化。

一,什么是MPM

       MPM,是Multi -Processing Modules的缩写,就是多处理模块的意思,它是在Apache 2.0中引入的一个概念,共引入目标是将Apache的结构能够模块化,把核心的任务处理作为一个可插拔的模块来运行,这样就很容易根据不同的环境和应用来更有效的优化Apache的运行,它是Apache2.X中最影响其性能的,最核心的特性,因为直接决定了Apache的工作方式。这里有一个问题是:它究竟怎么样影响了Apache。

      可以这么说:它决定了Apache以什么样的方式接入外部请求,如何Apache内部怎么样处理这个请求过程,这当然是最核心的了吧,比如它可以决定在处理外部请求的时候,需不需要启动多线程,如果是用多线程,最多可以多少个线程,一个进程可以产生最多多少个线程,类似于这种配置,都来自于MPM。MPM有一些指令可以专门用于调节父进程如何产生子进程,主要是StartServers,MinSpareServers,MaxSpareServers,MaxClients等,下面会介绍这些指令是什么意思。

它提供Apache服务程序和其所在的操作系统之间的接口,这个模块的主要职责是:

    根据Apache运行的操作系统平台来优化Apache。提高Apache的效率。保证Apache的安全。

其实MPM本身也是一个模块,它是Apache中唯一一个系统层的模块,Apache在编译的时候选定一个所要使用的MPM模块,我们先来了解一下MPM模块在系统结构中的位置

Apache的多处置模块MPM

在任何时候,一个正常的Apache都只有一个MPM模块在运行。

二,有哪些MPM可以被使用

在安装apache时,我们可以查看哪些MPM模块可以被使用。

ServerLimit 16StartServers 2MaxClients 150MinSpareThreads 25MaxSpareThreads 75ThreadsPerChild 25
五,小结
       Prefork MPM基于非线程模型,由独立的进程创建多个子进程的方式来工作,它在所有情况下都很安全,对运行非线程安全(non-thread-safe)模式的软件如PHP,它是唯一的安全选择。另外,对于某些应用程序,包括在 Apache 1.3上非常流行的程序(如简单静态页面、CGI脚本等),Prefork MPM是最好的选择。另一方面,prefork用单独的子进程来处理不同的请求,进程之间是彼此独立的,这也使其成为最稳定的MPM之一。但是由于每一个请求都会产生一个新的进程,导致系统资源(尤其是内存)消耗的很快,一旦并发量较大的时候,大量的Apache进程会占用巨大的内存空间。 
       Worker MPM基于线程模式,具有内存消耗低(对繁忙的服务很重要)、扩展性在某些特定应用情况下比Prefork更好等优点。在这个模式下,采用的进程和线程混合的形式处理请求。由于使用线程来处理,所以可以处理相对海量的请求,而系统资源的开销要小于基于进程的Prefork模式。
以上两种稳定的MPM方式在非常繁忙的服务器应用下都有些不足。尽管HTTP的Keepalive方式能减少TCP连接数量和网络负载,但是 Keepalive需要和服务进程或者线程绑定,这就导致一个繁忙的服务器会耗光所有的线程。

热点排行