忽然之间的博客

Thoughts, stories and ideas.

mod_php对比mod_fastcgi

什么是mod_php和mod_fastcgi 在lamp体系中,对于apache端的php的配置,我们最常用的就是mod_php,它把php作为apache一个内置的模块.让apache http服务器本身能够支持php语言,不需要每一个请求就启动php解释器来解释php. 和把webserver与php绑定起来的方式不同,fastcgi是http服务器与你的或其它机器上的程序进行“交谈”的一种工具,相当于一个程序接口。它可以接受来自web服务器的请求,解释输入信息,将处理后的结果返回给服务器等。mod_fastcgi就是在apache下支持fastcgi协议的模块。

SAPI和CLI SAPI(Server Application Programming Interface):服务器端应用程序接口 CLI(Command Line Interface):命令行接口

php运行原理

php运行原理

对于一个基于apache的php应用,运行流程可以简单归结为: Apache -< httpd -< mod_php -< fastcgi -< sapi -< php

mod_php 在lamp体系中,mod_php是最常使用的工作方式。在这种模式下,php被编译为apache的一个内置模块,在启动加载的时候,当有一个php请求过来,直接在httpd进程里完成了php的解释运行,将结果返回。工作原理如图所示:

1352901840_7545.jpg.jpeg

mod_fastcgi

普通cgi的工作流程: CGI英文全程是 Command Gateway Interface,通常翻译为公共网关接口,是HTTP服务器与机器上的其他程序进行通信的一个接口。这个“其他程序”可以是使用任何计算机语言进行编写,例如php,python,perl等等。它通过CGI这个接口从HTTP服务器取得输入,然后把运行结果又通过CGI这个接口交给HTTP服务器,而HTTP服务器把这个结果送给浏览器。 CGI的出现让WEB从静态变为动态,随着web的越来越普及,很多的网站都需要有动态的页面,以便与浏览者进行交互。CGI的缺点也越来越突出,因为HTTP要生成一个动态页面,系统就必须启动一个新的进程以运行CGI程序,不断的fork是一项很消耗时间和资源的工作。

fastcgi工作原理:

(1)web server 启动时载入Fastcgi进程管理器。[php的fastcgi进程管理器是PHP-FPM(php-FastCGI Process Manager)] (2)Fastcgi进程管理器自身初始化,启动多个CGI解释器进程并且等待来自web server的连接。启动php-cgi Fastcgi进程时,可以配置TCP和unix套接字两种方式。一般生产环境中采用TCP方式 (3)当客户端请求到达web server时,web server 通过tcp协议或者unix套接字的方式将请求转发给Fastcgi主进程,Fastcgi主进程选择并连接一个cgi进程。 (4)Fastcgi子进程完成php程序流程处理后将标准输出和错误信息一同返回给web server。当Fastcgi子进程关闭时,请求便告处理完成。Fastcgi子进程便接着等待来自Fastcgi进程管理器的下一个连接。 (5)fastcgi是基于cgi架构的扩展,他的核心思想就是在web server和具体cgi程序之间建立一个智能的可持续的中间层,统管cgi程序的运行,这样web server只需要将请求提交给这个层,这个层再派生出几个可复用的cgi程序实例,然后再把请求分发给这些实例,这些实例是可控的,可持续,可复用的。mod_fastcgi的主要优点是把动态语言和web server分离开来。这种技术允许把web server 和 动态语言运行在不同的主机上,以大规模扩展和改进安全性而不损失生产效率。 基于mod_fastcgi方式的php应用,工作流程如下:

1352903096_3206.jpg.jpeg

mod_fastcgi远程配置方式 fastcgi实例和apache分离开来,这两者可以分开来部署。他们之间的通信通过tcp或者unix sock来完成。使用ext方式,fastcgi实例是独立运行的。

php-fpm 使用fastcgi,最主要的优点是把应用和web server(apache)分离开来。这样允许把web server 和动态语言(php)运行在不同的主机上,以大规模扩展和改进安全性而不损失效率。 这样情况下,对于php-cgi程序,由于从apache中分离出来,就需要一个单独的工具来对这些进程进行管理,幸运的就是php-fpm的出现。

特性 (1)php守护进程:pid file,log file,setsid(),setuid(),setgid(),chroot() (2)进程控制,可以平滑的重启,重新载入配置和二进制模块而不丢失请求 (3)限制ip地址,可以满足web server的要求 (4)使用用不同的uid/gid/chroot/环境变量,不同的php.ini选项,不需要safe mode (5)记录word process的stdout和stderr (6)如果set_time_limit没有起作用,强制结束过期进程

特色功能: (1)fastcgi_finish_request()函数:响应完成,关闭连接 (2)优化上传支持 (3)特色功能Error header

参考文献: mod_php vs mod_fastcgi