Fastcgi和php-fpm的关系

本文通过生动的比喻介绍了FastCGI协议及其在Web服务器与PHP解析器之间的桥梁作用,并详细阐述了PHP-FPM如何作为FastCGI的实现之一,通过进程管理提升PHP应用的性能。


抽象化的说明Fastcgi和php-fpm的关系


你(PHP)去和日本人(web服务器,如 Apache、Nginx)谈生意

你说中文(PHP代码),他说日语(C代码),互相听不懂,怎么办?那就都把各自说的话转换成英语(FastCGI 协议)吧。

怎么转换呢?你就要使用一个翻译机(PHP-FPM)
(当然对方也有一个翻译机,那个是他自带的)

我们这个翻译机(PHP-FPM)是最新型的,老式的那个(PHP-CGI)被淘汰了。不过它(PHP-FPM)只有年轻人(Linux系统)会用,老头子们(Windows系统)不会摆弄它,只好继续用老式的那个。


Fastcgi和php-fpm的说明


CGI是为了保证web server传递过来的数据是标准格式的,方便CGI程序的编写者。

CGI是规定要传哪些数据、以什么样的格式传递给后方处理这个请求的协议,跟进程什么的没关系。。

web server(比如说nginx)只是内容的分发者。

举例:

如果请求/index.html,那么web server会去文件系统中找到这个文件,发送给浏览器,这里分发的是静态数据。而如果你现在请求的是/index.php,根据配置文件,nginx知道这个不是静态文件,需要去找PHP解析器来处理,那么他会把这个请求简单处理后交给PHP解析器。Nginx会传url、查询字符串、POST数据、HTTP header等等。

当web server收到/index.php这个请求后,会启动对应的CGI程序,这里就是PHP的解析器。接下来PHP解析器会解析php.ini文件,初始化执行环境,然后处理请求,再以规定CGI规定的格式返回处理后的结果,退出进程。web server再把结果返回给浏览器。

由此可知:php-cgi只是解释PHP脚本的程序而已


Fastcgi是用来提高CGI程序性能的


要理解Fastcgi,就要知道CGI程序的性能问题在哪呢?"PHP解析器会解析php.ini文件,初始化执行环境",问题就是这里了。标准的CGI对每个请求都会执行这些步骤(不闲累啊!启动进程很累的!),所以处理每个时间的时间会比较长。这明显不合理嘛!那么你现在就可能知道Fastcgi是做什么的了吧!首先,Fastcgi会先启一个master,解析配置文件,初始化执行环境,然后再启动多个worker。当请求过来时,master会传递给一个worker,然后立即可以接受下一个请求。这样就避免了重复的劳动,效率自然是提高。而且当worker不够用时,master可以根据配置预先启动几个worker等着;当然空闲worker太多时,也会停掉一些,这样不但提高了性能,而且节约了资源。这就是fastcgi的对进程的管理。


PHP-FPM是一个实现了Fastcgi的程序的(被PHP官方收了)

PHP的解释器是php-cgi。php-cgi只是个CGI程序,他自己本身只能解析请求,返回结果,不会进程管理,所以就出现了一些能够调度php-cgi进程的程序,比如说由lighthttpd分离出来的spawn-fcgi。好了PHP-FPM也是这么个东东,在长时间的发展后,逐渐得到了大家的认可并越来越流行。

Fastgic和php-fpm的关系说明


fastcgi是一个协议,php-fpm实现了这个协议

php-fpm的管理对象是php-cgi,用来管理fastcgi进程的,但不能说php-fpm是fastcgi进程的管理器,因为前面说了fastcgi是个协议,似乎没有这么个进程存在,就算存在php-fpm也管理不了他(至少目前是)。 

以前,因为最开始的时候php-fpm没有包含在PHP内核里面,要使用这个功能,需要找到与源码版本相同的php-fpm对内核打补丁,然后再编译。后来PHP内核集成了PHP-FPM之后就方便多了,使用--enalbe-fpm这个编译参数即可。


修改了php.ini配置文件后,php-cgi进程没办法平滑重启,所以就诞生了php-fpm。php-fpm对此的处理机制是新的worker用新的配置,已经存在的worker处理完手上的活就可以歇着了,通过这种机制来平滑过度。


不正确之处,感谢指出。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值