码迷,mamicode.com
首页 > Web开发 > 详细

Apache 的工作模式

时间:2017-03-09 23:04:17      阅读:220      评论:0      收藏:0      [点我收藏+]

标签:方式   稳定性   多进程   并发   多个   特性   平台   发展趋势   处理   

Apache 的工作模式

1.apache三种工作模式
我们都知道Apache有三种工作模块,分别为prefork、worker、event。
    prefork:多进程,每个请求用一个进程响应,这个过程会用到select机制来通知。
    worker:多线程,一个进程可以生成多个线程,每个线程响应一个请求,但通知机制还是select不过可以接受更多的请求。
    event:基于异步I/O模型,一个进程或线程,每个进程或线程响应多个用户请求,它是基于事件驱动(也就是epoll机制)实现的。

2.prefork的工作原理
       如果不用“--with-mpm”显式指定某种MPM,prefork就是Unix平台上缺省的MPM.它所采用的预派生子进程方式也是 Apache1.3中采用的模式.prefork本身并没有使用到线程,2.0版使用它是为了与1.3版保持兼容性;另一方面,prefork用单独的子 进程来处理不同的请求,进程之间是彼此独立的,这也使其成为最稳定的MPM之一。

3.worker的工作原理
       相对于prefork,worker是2.0版中全新的支持多线程和多进程混合模型的MPM.由于使用线程来处理,所以可以处理相对海量的请求,而 系统资源的开销要小于基于进程的服务器.但是,worker也使用了多进程,每个进程又生成多个线程,以获得基于进程服务器的稳定性.这种MPM的工作方 式将是Apache2.0的发展趋势。

4.event 基于事件机制的特性
       一个进程响应多个用户请求,利用callback机制,让套接字复用,请求过来后进程并不处理请求,而是直接交由其他机制来处理,通过epoll机制来通知请求是否完成;在这个过程中,进程本身一直处于空闲状态,可以一直接收用户请求。可以实现一个进程程响应多个用户请求。支持持海量并发连接数,消耗更少的资源。

Apache 的工作模式

标签:方式   稳定性   多进程   并发   多个   特性   平台   发展趋势   处理   

原文地址:http://www.cnblogs.com/sunziying/p/6528214.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!