• Floating production, storage and offloading vessel delivered in Qingdao 2018-05-20
  • 汽車定位跟蹤官員意圖敲詐 追蹤器該怎麼管 2018-05-20
  • 工作队精准发力助力贫困村“摘帽” 2018-05-20
  • 中消协发布榨汁机比较试验结果 2018-05-20
  • 游花海林芝,赏野生桃花 2018林芝桃花节29日开幕 2018-05-20
  • 19米99轻松卫冕 巩立姣:没突破20米有点可惜 2018-05-18
  • 海南省工商局出实招提高干部素质 强化工作作风 2018-05-18
  • 栾蕾英亮相TOP100时尚盛典 盛装亮相仙气十足 2018-05-18
  • 以合法形式掩盖非法目的的合同效力 2018-05-18
  • 4月解放领跑重卡行业 红岩保持增幅第一 2018-05-17
  • 不查“后来”,中国电影难有未来 2018-05-16
  • 欧盟公司与伊朗合作将遭美国制裁?德媒:欧美或渐行渐远 2018-05-16
  • 《青草的清香》:探索感官和情感的发展史 2018-05-16
  • 徒步穿越纪念汶川地震十周年 2018-05-16
  • 警方提示:提防打火机、香水让车辆“上火” 2018-05-15
  • 从运行原理及使用场景看Apache和Nginx

    栏目: web服务器 发布于: 2014-02-21 13:28:51

    本文只作为了解Apache和Nginx知识的一个梳理,想详细了解的请阅读文末参考链接中的博文。

    Web服务器

    Web服务器也称为WWW(WORLD WIDE WEB)服务器,主要功能是提供网上信息浏览服务。

        1、应用层使用HTTP协议。

        2、HTML文档格式。

        3、浏览器统一资源定位器(URL)。

    Web服务器常常以B/S(Browser/Server)方式提供服务。浏览器和服务器的交互方式如下:

    GET /index.php HTTP/1.1
    
     +---------------+                   +----------------+
     |               +------------------->                |
     |   Browser     |                   |   Server       |
     |               <-------------------+                |
     +---------------+                   +----------------+
    
                       HTTP/1.1 200 OK
        1、浏览器向服务器发出HTTP请求(Request)。

        2、服务器收到浏览器的请求数据,经过分析处理,向浏览器输出响应数据(Response)。

        3、浏览器收到服务器的响应数据,经过分析处理,将最终结果显示在浏览器中。

    Apache和Nginx都属于Web服务器,两者都实现了HTTP 1.1协议。

    Apache

    概述

    Apache HTTP Server是Apache软件基金会的一个开放源代码的网页服务器,可以在大多数计算机操作系统中运行,由于其跨平台和安全性。被广泛使用,是最流行的Web服务器端软件之一。它快速、可靠并且可通过简单的API扩充,将Perl/Python等解释器编译到服务器中。 -- 维基百科

    Apache组件

    Apache是基于??榛杓频?,它的核心代码并不多,大多数的功能都被分散到各个??橹?,各个??樵谙低称舳氖焙虬葱柙厝?。

    +----------+
          +- | Module   | -----------------+
          |  +----------+                  |
          |                          +------------+
    +-----------+   Apache HTTPD     | php module |
    | Module    |                    +------------+
    +-----------+              +----------+|
          +----------+-------- |  MPM     |+
                     |         +----+---+-+
                   +-v-----------+  |   |
                   |    ARP      <--+   |
                   +------+------+      |
                          |             |
          +---------------v-------------v--+
          |      Operating  System         |
          +--------------------------------+
    MPM(Multi -Processing Modules,多重处理??椋┦茿pache的核心组件之一,Apache通过MPM来使用操作系统的资源,对进程和线程池进行管理。Apache为了能够获得最好的运行性能,针对不同的平台 (Unix/Linux、Window)做了优化,为不同的平台提供了不同的MPM,用户可以根据实际情况进行选择,其中最常使用的MPM有 prefork和worker两种。至于您的服务器正以哪种方式运行,取决于安装Apache过程中指定的MPM编译参数,在X系统上默认的编译参数为 prefork。

    由于大多数的Unix都不支持真正的线程,所以采用了预派生子进程(prefork)方式,象Windows或者Solaris这些支持 线程的平台,基于多进程多线程混合的worker模式是一种不错的选择。Apache中还有一个重要的组件就是APR(Apache portable Runtime Library),即Apache可移植运行库,它是一个对操作系统调用的抽象库,用来实现Apache内部组件对操作系统的使用,提高系统的可移植性。 Apache对于php的解析,就是通过众多Module中的php Module来完成的。

    Apache生命周期

       +--------------------------------------------------------------+
       |                 +---------------------+       启动阶段        |
       |                 |    系统启动, 配置     |                      |
       |                 +----------+----------+                      |
       |                            |                                 |
       |                 +----------v----------+                      |
       |                 |      ??榈某跏蓟?    |                      |
       |                 +-+--------+--------+-+                      |
       |                   |        |        |                        |
       |   +-------------+ | +------v-------+| +--------------+       |
       |   | 子进程初始化  |<+ | 子进程初始化   |+>|  子进程初始化  |       |
       |   +------+------+   +-------+------+  +-------+------+       |
       +--------------------------------------------------------------+
       |          |                  |                 |     运行阶段  |
       |     +----v----+        +----v----+       +----v----+         |
       |     | 请求循环 |        |  请求循环 |       | 请求循环 |         |
       |     +----+----+        +----+----+       +----+----+         |
       |          |                  |                 |              |
       |   +------v------+    +------v------+   +------v------+       |
       |   |  子进程结束   |    |  子进程结束  |   |   子进程结束  |       |
       |   +-------------+    +-------------+   +-------------+       |
       +--------------------------------------------------------------+
    这个生命周期是在perfork工作下的示意,从图中可以看出,Apache对于每一个请求都要启动一个单独的进程来处理。

    Apache的工作模式

    prefork的工作原理

    一个单独的控制进程(父进程)负责产生子进程,这些子进程用于监听请求并作出应答。Apache总是试图保持一些备用的 (spare)或是空闲的子进程用于迎接即将到来的请求。这样客户端就无需在得到服务前等候子进程的产生。在Unix系统中,父进程通常以root身份运行以便邦定80端口,而 Apache产生的子进程通常以一个低特权的用户运行。User和Group指令用于配置子进程的低特权用户。运行子进程的用户必须要对他所服务的内容有读取的权限,但是对服务内容之外的其他资源必须拥有尽可能少的权限。

    worker的工作原理

    每个进程能够拥有的线程数量是固定的。服务器会根据负载情况增加或减少进程数量。一个单独的控制进程(父进程)负责子进程的建立。每个子进程能够建立ThreadsPerChild数量的服务线程和一个监听线程,该监听线程监听接入请求并将其传递给服务线程处理和应答。Apache总是试图维持一个备用(spare)或是空闲的服务线程池。这样,客户端无须等待新线程或新进程的建立即可得到处理。在Unix中,为了能够绑定80端口,父进程一般都是以root身份启动,随后,Apache以较低权限的用户建立子进程和线程。User和Group指令用于配置Apache子进程的权限。虽然子进程必须对其提供的内容拥有读权限,但应该尽可能给予他较少的特权。另外,除非使用了suexec ,否则,这些指令配置的权限将被CGI脚本所继承。

    Apache的运行

    启动阶段

    在启动阶段,Apache主要进行配置文件解析(例如http.conf以及Include指令设定的配置文件等)、??榧釉?例如modphp.so,modperl.so等)和系统资源初始化(例如日志文件、共享内存段等)工作。在这个阶段,Apache为了获得系统资源最大的使用权限,将以特权用户root(X系统)或超级管理员administrator(Windows系统)完成启动。

    这个过程可以通过下图来深入了解:

           +--------+      
           |  开始   |      
           +----+---+         
                |
     +----------v------------+   解析主配置文件http.conf中配置信息, 
     |     解析配置文件        |   像LoadModule, AddType
     +----------+------------+   等指令被加载至内存
                |
     +----------v------------+   依据AddModule, LoadModule等指令
     |   加载静态/动态???     |   加载Apache???,像mod_php5.so被
     +----------+------------+   加载至内存,映射到Apache地址空间。
                |
     +----------v------------+   日志文件、共享内存段,数据库链接
     |     系统资源初始化      |    等初始化
     +----------+------------+
                |
            +---v----+
            |  结束   |
            +--------+
    运行阶段

    在运行阶段,Apache主要工作是处理用户的服务请求。在这个阶段,Apache放弃特权用户级别,使用普通权限,这主要是基于安全性的考虑,防止由于代码的缺陷引起的安全漏洞。

    由于Apache的Hook机制,Apache 允许???包括内部??楹屯獠磕??,例如mod_php5.so,mod_perl.so等)将自定义的函数注入到请求处理循环中。mod_php5.so/php5apache2.dll就是将所包含的自定义函数,通过Hook机制注入到Apache中,在Apache处理流程的各个阶段负责处理php请求。

    Apache将请求处理循环分为11个阶段,依次是:Post-Read-Request,URI Translation,Header Parsing,Access Control,Authentication,Authorization,MIME Type Checking,FixUp,Response,Logging,CleanUp。

    Apache处理http请求的生命周期:

        1、Post-Read-Request阶段:在正常请求处理流程中,这是??榭梢圆迦牍匙拥牡谝桓鼋锥?。对于那些想很早进入处理请求的??槔此?,这个阶段可以被利用。

        2、URI Translation阶段 : Apache在本阶段的主要工作:将请求的URL映射到本地文件系统。??榭梢栽谡饨锥尾迦牍匙?,执行自己的映射逻辑。mod_alias就是利用这个阶段工作的。

        3、Header Parsing阶段 : Apache在本阶段的主要工作:检查请求的头部。由于??榭梢栽谇肭蟠砹鞒痰娜魏我桓龅闵现葱屑觳榍肭笸凡康娜挝?,因此这个钩子很少被使用。mod_setenvif就是利用这个阶段工作的。

        4、Access Control阶段 : Apache在本阶段的主要工作:根据配置文件检查是否允许访问请求的资源。Apache的标准逻辑实现了允许和拒绝指令。modauthzhost就是利用这个阶段工作的。

        5、Authentication阶段 : Apache在本阶段的主要工作:按照配置文件设定的策略对用户进行认证,并设定用户名区域。??榭梢栽谡饨锥尾迦牍匙?,实现一个认证方法。

        6、Authorization阶段 : Apache在本阶段的主要工作:根据配置文件检查是否允许认证过的用户执行请求的操作。??榭梢栽谡饨锥尾迦牍匙?,实现一个用户权限管理的方法。

        7、MIME Type Checking阶段 : Apache在本阶段的主要工作:根据请求资源的MIME类型的相关规则,判定将要使用的内容处理函数。标准??閙odnegotiation和modmime实现了这个钩子。

        8、FixUp阶段 : 这是一个通用的阶段,允许??樵谀谌萆善髦?,运行任何必要的处理流程。和PostReadRequest类似,这是一个能够捕获任何信息的钩子,也是最常使用的钩子。

        9、Response阶段 : Apache在本阶段的主要工作:生成返回客户端的内容,负责给客户端发送一个恰当的回复。这个阶段是整个处理流程的核心部分。

        10、Logging阶段 : Apache在本阶段的主要工作:在回复已经发送给客户端之后记录事务。??榭赡苄薷幕蛘咛婊籄pache的标准日志记录。

        11、CleanUp阶段 : Apache在本阶段的主要工作:清理本次请求事务处理完成之后遗留的环境,比如文件、目录的处理或者Socket的关闭等等,这是Apache一次请求处理的最后一个阶段。

    Nginx

    概述

    Nginx(发音同engine x)是一款由俄罗斯程序员Igor Sysoev所开发轻量级的网页服务器、反向代理服务器以及电子邮件(IMAP/POP3)代理服务器。起初是供俄国大型的门户网站及搜索引擎Rambler(俄语:Рамблер)使用。 -- 维基百科

    Nginx的??橛牍ぷ髟?/strong>

    Nginx由内核和??樽槌?,其中,内核的设计非常微小和简洁,完成的工作也非常简单,仅仅通过查找配置文件将客户端请求映射到一个location block(location是Nginx配置中的一个指令,用于URL匹配),而在这个location中所配置的每个指令将会启动不同的??槿ネ瓿上嘤Φ墓ぷ?。

    Nginx的??榇咏峁股戏治诵哪??、基础??楹偷谌侥?椋?/strong>

        1、核心??椋篐TTP???、EVENT??楹蚆AIL???/span>

        2、基础??椋篐TTP Access???、HTTP FastCGI???、HTTP Proxy??楹虷TTP Rewrite???,

        3、第三方??椋篐TTP Upstream Request Hash???、Notice??楹虷TTP Access Key???。

    Nginx的??榇庸δ苌戏治缦氯?

        1、Handlers(处理器??椋?。此类??橹苯哟砬肭?,并进行输出内容和修改headers信息等操作。Handlers处理器??橐话阒荒苡幸桓?。

        2、Filters (过滤器??椋?。此类??橹饕云渌砥髂?槭涑龅哪谌萁行薷牟僮?,最后由Nginx输出。

        3、Proxies (代理类??椋?。此类??槭荖ginx的HTTP Upstream之类的???,这些??橹饕牒蠖艘恍┓癖热鏔astCGI等进行交互,实现服务代理和负载均衡等功能。

                         +                    ^
            Http Request |                    |  Http Response
                         |                    |
        +---------+------v-----+         +----+----+
        |  Conf   | Nginx Core |         | FilterN |
        +---------+------+-----+         +----^----+
                         |                    |
                         |               +----+----+
                         |               | Filter2 |
    choose a handler     |               +----^----+
    based conf           |                    |
                         |               +----+----+
                         |               | Filter1 |
                         |               +----^----+
                         |                    | Generate content
                   +-----v--------------------+----+
                   |           Handler             |
                   +-------------------------------+
    Nginx本身做的工作实际很少,当它接到一个HTTP请求时,它仅仅是通过查找配置文件将此次请求映射到一个location block,而此location中所配置的各个指令则会启动不同的??槿ネ瓿晒ぷ?,因此??榭梢钥醋鯪ginx真正的劳动工作者。通常一个location中的指令会涉及一个handler??楹投喔鰂ilter??椋ǖ比?,多个location可以复用同一个??椋?。handler??楦涸鸫砬肭?,完成响应内容的生成,而filter??槎韵煊δ谌萁写?。

    Nginx架构及工作流程

    上图是Nginx的架构,这个架构类似于Apache的Worker工作状态,Nginx的每一个Worker进程都管理着大量的线程,真正处理请求的是Worker之下的线程。

    所有实际上的业务处理逻辑都在worker进程。worker进程中有一个函数,执行无限循环,不断处理收到的来自客户端的请求,并进行处理,直到整个nginx服务被停止。Worker中这个函数执行内容如下:

        1、操作系统提供的机制(例如epoll, kqueue等)产生相关的事件。

        2、接收和处理这些事件,如是接受到数据,则产生更高层的request对象。

        3、处理request的header和body。

        4、产生响应,并发送回客户端。

        5、完成request的处理。

        6、重新初始化定时器及其他事件。

    Nginx和FastCGI

    FastCGI

    FastCGI是一个可伸缩地、高速地在HTTP server和动态脚本语言间通信的接口。多数流行的HTTP server都支持FastCGI,包括Apache、Nginx和lighttpd等。同时,FastCGI也被许多脚本语言支持,其中就有PHP。

    FastCGI是从CGI发展改进而来的。传统CGI接口方式的主要缺点是性能很差,因为每次HTTP服务器遇到动态程序时都需要重新启动脚本解析器来执行解析,然后将结果返回给HTTP服务器。这在处理高并发访问时几乎是不可用的。另外传统的CGI接口方式安全性也很差,现在已经很少使用了。

    FastCGI接口方式采用C/S结构,可以将HTTP服务器和脚本解析服务器分开,同时在脚本解析服务器上启动一个或者多个脚本解析守护进程。当HTTP服务器每次遇到动态程序时,可以将其直接交付给FastCGI进程来执行,然后将得到的结果返回给浏览器。这种方式可以让HTTP服务器专一地处理静态请求或者将动态脚本服务器的结果返回给客户端,这在很大程度上提高了整个应用系统的性能。

    Nging和FastCGI合作

    Nginx不支持对外部程序的直接调用或者解析,所有的外部程序(包括PHP)必须通过FastCGI接口来调用。FastCGI接口在Linux下是socket(这个socket可以是文件socket,也可以是ip socket)。

    接下来以Nginx下PHP的运行过程来说明。PHP-FPM是管理FastCGI的一个管理器,它作为PHP的插件存在。

        1、FastCGI进程管理器php-fpm自身初始化,启动主进程php-fpm和启动start_servers个CGI 子进程。主进程php-fpm主要是管理fastcgi子进程,监听9000端口。fastcgi子进程等待来自Web Server的连接。

        2、当客户端请求到达Web Server Nginx是时,Nginx通过location指令,将所有以php为后缀的文件都交给127.0.0.1:9000来处理,即Nginx通过location指令,将所有以php为后缀的文件都交给127.0.0.1:9000来处理。

        3、FastCGI进程管理器PHP-FPM选择并连接到一个子进程CGI解释器。Web server将CGI环境变量和标准输入发送到FastCGI子进程。

        4、FastCGI子进程完成处理后将标准输出和错误信息从同一连接返回Web Server。当FastCGI子进程关闭连接时,请求便告处理完成。

        5、FastCGI子进程接着等待并处理来自FastCGI进程管理器(运行在 WebServer中)的下一个连接。

    Apache和Nginx比较

    功能对比

    Nginx和Apache一样,都是HTTP服务器软件,在功能实现上都采用??榛峁股杓?,都支持通用的语言接口,如PHP、Perl、Python等,同时还支持正向和反向代理、虚拟主机、URL重写、压缩传输、SSL加密传输等。

        1、在功能实现上,Apache的所有??槎贾С侄?、静态编译,而Nginx??槎际蔷蔡嘁氲?,

        2、对FastCGI的支持,Apache对Fcgi的支持不好,而Nginx对Fcgi的支持非常好;

        3、在处理连接方式上,Nginx支持epoll,而Apache却不支持;

        4、在空间使用上,Nginx安装包仅仅只有几百K,和Nginx比起来Apache绝对是庞然大物。

    Nginx相对apache的优点

        1、轻量级,同样起web 服务,比apache 占用更少的内存及资源

        2、静态处理,Nginx 静态处理性能比 Apache 高 3倍以上

        3、抗并发,nginx 处理请求是异步非阻塞的,而apache则是阻塞型的,在高并发下nginx 能保持低资源低消耗高性能。在Apache+PHP(prefork)模式下,如果PHP处理慢或者前端压力很大的情况下,很容易出现Apache进程数飙升,从而拒绝服务的现象。

        4、高度??榛纳杓?,编写??橄喽约虻?/span>

        5、社区活跃,各种高性能??槌銎费杆侔?/span>

    apache相对nginx的优点

        1、rewrite,比nginx 的rewrite 强大

        2、??槌?,基本想到的都可以找到

        3、少bug,nginx的bug相对较多

        4、超稳定

        5、Apache对PHP支持比较简单,Nginx需要配合其他后端用

    选择Nginx的优势所在

        1、作为Web服务器: Nginx处理静态文件、索引文件,自动索引的效率非常高。

        2、作为代理服务器,Nginx可以实现无缓存的反向代理加速,提高网站运行速度。

        3、作为负载均衡服务器,Nginx既可以在内部直接支持Rails和PHP,也可以支持HTTP代理服务器对外进行服务,同时还支持简单的容错和利用算法进行负载均衡。

        4、在性能方面,Nginx是专门为性能优化而开发的,在实现上非常注重效率。它采用内核Poll模型(epoll and kqueue ),可以支持更多的并发连接,最大可以支持对50 000个并发连接数的响应,而且只占用很低的内存资源。

        5、在稳定性方面,Nginx采取了分阶段资源分配技术,使得CPU与内存的占用率非常低。Nginx官方表示,Nginx保持10 000个没有活动的连接,而这些连接只占用2.5MB内存,因此,类似DOS这样的攻击对Nginx来说基本上是没有任何作用的。

        6、在高可用性方面,Nginx支持热部署,启动速度特别迅速,因此可以在不间断服务的情况下,对软件版本或者配置进行升级,即使运行数月也无需重新启动,几乎可以做到7×24小时不间断地运行。

    同时使用Nginx和Apache

    由于Nginx和Apache各自的优势,现在很多人选择了让两者在服务器中共存。在服务器端让Nginx在前,Apache在后。由Nginx做负载均衡和反向代理,并且处理静态文件,讲动态请求(如PHP应用)交给Apache去处理。

    参考

        1、Apache运行机制剖析

        2、Apache处理http请求的生命周期

        3、Nginx平台初探

        4、Nginx架构综述

        5、Apache, nginx, lighttpd性能比较

    转载自:http://www.rocksun.cn/2014/02/15/apache-and-nginx.html

    本站文章除注明转载外,均为本站原创或编译?;队魏涡问降淖?,但请务必注明出处。
    转载请注明:文章转载自 七星彩票平台
    本文标题:从运行原理及使用场景看Apache和Nginx
    IT技术书籍推荐:
    PHP编程(第3版)
    PHP编程(第3版)
    凯文·塔特罗 (Kevin Tatroe) (作者), 彼得·麦金太尔 (Peter MacIntyre) (作者), 拉斯马斯·勒多夫 (Rasmus Lerdorf) (作者), 赵戈戈 (译者), 易国磐 (译者), 张鹏飞 (译者)
    这是一本可以让读者深入了解PHP 技术的书籍,作者用言简意赅的语言并结合了大量实例来解释每一个要素。本书涵盖了PHP 所有基本的要点,不管你是一个想从头开始学习PHP的人,还是对PHP 已经有了基础想继续深入的人,这本书都很合适。