Apache服务的工作模式

  

Apache工作模式介绍

  
      <李>   

    Apache作为现今web服务器用的最广泛也是最稳定的开源服务器软件

      李   <李>其工作模式有许多种,源码包安装httpd时可查看httpd-mpm.conf文件,该文件位于额外的/conf目录中李   
  

目前主要有三种模式:

  
      <李>   

    事件模式

      李   <李>   

    prefork模式

      李   <李>   

    工模式

      李   
  

事件工作模式介绍

  
      <李>   

    事件是Apache最新的工作模式,它和工模式很像,不同的是在于它解决了维生长连接的时候占用线
    程资源被浪费的问题

      李   <李>   

    事件工作模式在遇到某些不兼容的模块时,会失效,将会回退到工模式

      李   <李>事件工作模式需要Linux系统(Linux 2.6 +)对epoll的支持,才能启用。需要补充的是HTTPS的连接(SSL)   
  

事件工作方式

  
      <李>   

    在事件工作模式中,会有一些专门的线程用来管理这些维生类型的线程

      李   <李>   

    当有真实请求过来的时候,将请求传递给服务器的线程,执行完毕后,又允许它释放

      李   <李>这样,一个线程就能处理几个请求了,实现了异步非阻塞。这增强了在高并发场景下的请求处理李   
  

事件参数讲解

  

在httpd-mpm.conf配置文件中,以下是事件模块的定义:

  
 <代码> & lt; IfModule mpm_event_module>
  StartServers 3
  MinSpareThreads 75
  MaxSpareThreads 250
  ThreadsPerChild 25
  MaxRequestWorkers 400
  MaxConnectionsPerChild 0
  & lt;/IfModule>  
           参数   说明               StartServers   服务启动时初始的进程数,默认3         MinSpareThreads   最小的空闲子进程数,默认75         MaxSpareThreads   最大的空闲子进程数,默认250         ThreadsPerChild   每个子进程产生的线程数量,默认是25         MaxRequestWorkers   限定同一时间内客户端最大接入的请求数量,默认是400         MaxConnectionsPerChild   每个子进程在其生命周期内允许最大的请求数量,如果请求总数已经达到这个数值,子进程将会结束,如果设置为0,子进程将永远不会结束。将该值设置为非0值,可以防止运行PHP导致的内存泄露            

prefork工作模式介绍

  
      <李>   

    prefork是一般个多路处理模块(MPM),实现了一个进程型的,预派生的web服务器,适合于没有线程安全库,需要避免线程兼容性问题的系统

      李   <李>   

    在要求每个请求相互独立的情况下具有很好的特性,若一个请求出现问题不会影响到其他请求

      李   <李>   

    具有很强的自我调节能力,只需要很少的配置指令进行调整就可以适合于企业应用要求

      李   <李>最重要的是将数设置为一个足够大的数值以处理潜在的请求高峰同时又不能太大,以避免所需的内存超出物理内存的大小李   
  

prefork工作模方式

  
      <李>   

    一个单独的控制进程(父进程)负责产生子进程,子进程用于监听请求并作出应答,因此在内存中会一直存在一些备用的(业余)或是空闲的子进程用于响应新的请求,可加快响应速度

      李   <李>   

    父进程通常以根身份运行,以便绑定80端口,子进程通常以一个低特权的用户运行,可通过配置项的用户和组配置

      李   <李>   

    运行子进程的用户必须要对网站内容有读取权限,但是对其他资源必须拥有尽可能少的权限,以保证系统安全

      李   <李>编译安装时没有指定工作模式,默认会使用prefork模式,可用httpd - l查看李   
  

prefork参数讲解

  

在httpd-mpm.conf配置文件中,以下是prefork模块的定义

  
 <代码> & lt; IfModule mpm_prefork_module>
  StartServers 20
  MinSpareServers 10
  MaxSpareServers 50
  数150
  MaxRequestsPerChild 0
  & lt;/lfModule>  
           参数   说明               ServerLimit   最大进程数         StartServers   启动的时候创建的进程数量         MinSpareServers   最少空闲进程         MaxSpareServers   最多空闲进程         数   最多创建多少个子进程用来处理请求         MaxRequestsPerChild   每个进程处理的最大请求数,达到请求数,进程即被销毁,如果设置为0,子进程永远不会结束            

Apache服务的工作模式