转载请注明文章出处: https://tlanyan.me/php-review...
本文总结PHP的执行流程以及相关概念。php
先看看运行一个PHP程序须要哪些支撑。一切的起点,要从程序员开始写PHP才有意义,因此应用层面的PHP脚本文件(包括Composer/include的各类第三方PHP代码)是必须的。脚本文件要解析编译后才能执行,因此PHP虚拟机(一般是Zend引擎)也是必备的。此外PHP脚本中会使用多个拓展中的函数和类,因此拓展(包括官方、PECL、以及用户自行写的拓展)几乎也是必备的。另外PHP程序要与外部交互(例如从命令行获取参数、从web服务器获取请求信息),这一层由SAPI负责,因此SAPI也是必须的。程序员
总结以上,PHP程序的架构从上往下看有四层,分别是:应用层、SAPI层、拓展层和Zend引擎。架构关系见下图:web
(图片来源:http://www.nowamagic.net/libr...)数据库
SAPI层对某些人可能相对陌生。SAPI提供一套统一的接口,让上层应用程序与实际运行环境解耦。用户写的PHP文件,能够用命令行执行,也能够在Apache httpd或FPM中执行。背后的支持工做由SAPI提供,开发人员无感知。经过SAPI,PHP脚本层无需过多考虑执行的具体环境,而PHP自己则可让SAPI针对本身的特色给出特有实现。apache
抛开各个SAPI实现上的差别,PHP程序的执行流程能够简单归结以下:编程
除345,其他几步在整个SAPI生命周期中只会执行一次。CGI/CLI模式下,345也只执行一次。安全
理解PHP程序的生命周期,是PHP进阶的必备过程,也能帮助开发人员快速定位问题。例如脚本报函数不存在,颇有多是某个拓展缺失或加载出错;在CLI/CGI模式下,再怎么pconnect
也是徒劳的,脚本一执行完资源就释放掉;exit/die
终止的是脚本的执行,不必定意味着进程的结束;脚本编译后常驻内存,不会反复执行RINIT和RSHUTDOWN,是CLI框架相对于其余运行模式的性能提高点;等等。服务器
SAPI生命周期中各个阶段的更多细节,请参考《深刻理解PHP内核》一书。cookie
CGI/FastCGI/php-cgi和PHP-FPM是几个容易让PHP开发人员困惑和混淆的概念。这几个概念的关系以下:session
CGI/FastCGI:网关协议,与语言无关,因此与PHP关系也不大。二者的区别是FastCGI能够独立于web服务器,运行FastCGI协议的程序变成web服务器的内容提供方(上游)。另外与web服务器解耦后,用FastCGI协议交互的进程具备性能好、安全稳定、支持分布式等优势; php-cgi:实现FastCGI协议的PHP解析器,不能平滑重启和热加载; FPM:PHP官方的FastCGI进程管理器,可执行程序为php-fpm;支持平滑重启、热加载,运行稳定;其管理对象不是php-cgi进程,二者没什么关系。
仅是几个概念比较容易容易区分,实际上混淆开发人员的是如下四组概念的综合:
因为web服务器对大多数人更熟悉,拿之说一下与其余概念的关系:使用Apache httpd时,90%以上的状况以模块方式执行PHP脚本,因此与SAPI中的apache2handler有关,与其余概念无关(既不是CGI也不是FastCGI协议);使用Nginx时,90%的状况是经过FastCGI协议将请求转发到FPM,因此与SAPI中的fpm-fcgi、协议中的FastCGI、程序中的php-fpm三个概念有关,与其余概念无关。
本文简要回顾了PHP程序的架构和执行流程,并对几个容易混淆概念作了介绍。
感谢阅读,欢迎指正!