什么是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运行原理
对于一个基于apache的php应用,运行流程可以简单归结为:
Apache -> httpd -> mod_php -> fastcgi -> sapi -> php
mod_php
在lamp体系中,mod_php是最常使用的工作方式。在这种模式下,php被编译为apache的一个内置模块,在启动加载的时候,当有一个php请求过来,直接在httpd进程里完成了php的解释运行,将结果返回。工作原理如图所示:
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应用,工作流程如下:
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