认识PHP运行模式

PHP有五种运行模式,常见的有4种:

  1. CGI(通用网关接口/ Common Gateway Interface)
  2. FastCGI(常驻型CGI / Long-Live CGI)
  3. CLI(命令行运行 / Command Line Interface)
  4. LoadModule【Apache独有】
  5. ISAPI(Internet Server Application Program Interface)【IIS独有】

备注:在PHP5.3以后,PHP不再有ISAPI模式,安装后也不再有php5isapi.dll这个文件。要在IIS6上使用高版本PHP,必须安装FastCGI 扩展,然后使IIS6支持FastCGI。

查看当前运行模式
echo php_sapi_name();

CGI模式

介绍:

CGI即通用网关接口(Common Gateway Interface),它是一段程序,通俗的讲CGI就象是一座桥,把网页和Web服务器中的执行程序连接起来,它把HTML接收的指令传递给服务器的执行程序,再把服务器执行程序的结果返还给HTML页。CGI 的跨平台性能极佳,几乎可以在任何操作系统上实现。

调用过程:Fork-And-Execute模式

用户请求 —> web服务器接收请求【常用Nginx、apache】—> fork CGI的子进程&处理请求 ----> 请求处理完毕,返回结果到web服务器&销毁子进程 —> web服务器返回结果给用户

图解:
认识PHP运行模式_第1张图片
优势:

作为PHP最早的运行模式,每次请求都独立处理,调用过程足够简单清晰,可控性强
进程间是隔离的,保证数据不会被污染

劣势:

每次请求都需要fork一个新的CGI子进程,假如同一时间并发请求一千,意味着就要fork一千个子进程,这就会导致几个问题:

  1. fork子进程需要时间,需要占用内存【copy-on-write】
  2. 子进程过多,会导致CPU将大量的时间花费在上下文切换上
  3. 每次请求需要重新加载相关资源

FastCGI模式

介绍:

FastCGI是CGI的升级版本,FastCGI像是一个常驻 (long-live)型的 CGI,在启动web服务器的时候载入FastCGI进程管理器【PHP-FPM、IIS ISAPI、Apache Module】,当有请求过来的时候,web服务器只需要交给FastCGI进程管理器处理即可。
调用过程:以 PHP-FPM 为例

web服务器启动的时候 启动 PHP-FPM master进程(主要负责分配请求给空闲的自子进程处理)以及一定数量的fast-cgi子进程(负责处理请求)。 PHP-FPM master进程管理一个进程池,池里有若干个fast-cgi子进程,每个fast-cgi子进程单独处理一个请求,互不干涉。

用户请求 —> web服务器接收请求【常用Nginx、apache】—> 检测到是PHP请求&转发给FPM master进程 —> FPM master进程 指定空闲fast-cgi子进程处理请求 —> 子进程载入文件(如php.ini)及其他资源处理请求 —> 处理结束&清除资源,结果返回master & 子进程挂起,标记为空闲—> master 将结果返回web服务器 —> web服务器返回结果给用户

图解:
认识PHP运行模式_第2张图片
优势:

  1. 从稳定性上看,FastCGI是以独立的进程池来运行CGI,单独一个进程死掉,系统可以很轻易的丢弃,然后重新分配新的进程来运行逻辑
  2. 从安全性上看,FastCGI和宿主的web Server完全独立,FastCGI 不会影响web 服务器的运行【如果PHP-FPM处于关闭状态,则会返回502 bad gateway 给用户】
  3. 从性能上看,FastCGI把动态逻辑的处理从 web Server中分离出来,大负荷的IO处理还是留给宿主Server,这样宿主Server可以一心一意作IO【对于一个普通的动态网页来说, 逻辑处理可能只有一小部分,更多的是图片等静态资源的加载】

劣势:

一个fast-cgi子进程同一时间只能处理一个请求,所以网站的并发性能就受限于子进程数量
如果开启的进程过多,会导致CPU将大量的时间浪费在进程的上下文切换上。
每次请求fast-cgi子进程都需要重新加载相关资源,请求结束需要释放资源

CLI(命令行运行 / Command Line Interface)

简介:

php-cli模式属于命令行模式,对于很多刚开始学php就开始wamp,wnmp的开发者来说是最陌生的一种运行模式
该模式不需要借助其他程序,直接输入php xx.php 就能执行php代码
命令行模式和常规web模式明显不一样的是:
没有超时时间
默认关闭buffer缓冲
STDIN和STDOUT标准输入/输出/错误 的使用
echo var_dump,phpinfo等输出直接输出到控制台
可使用的类/函数 不同
php.ini配置的不同

PS:详见官方文档:https://www.php.net/manual/zh/features.commandline.php

LoadModule(Apache独有)

简介:
模块模式是以mod_php5模块的形式集成,此时mod_php5模块的作用是接收Apache传递过来的PHP文件请求,并处理这些请求,然后将处理后的结果返回给Apache。
在Apache配置文件httpd.conf里,通常加的LoadModule php7_module “D:/…/php71/php7apache2_4.dll”起到的作用就是这个

调用过程:

用户请求 —> Apache 服务器 —> 调用mod_php5模块处理请求 —> 返回请求结果给Apache —> Apache 返回结果给用户

图解:
认识PHP运行模式_第3张图片

ISAPI(Internet Server Application Program Interface)

简介:

在PHP5.3以后,PHP不再有ISAPI模式,安装后也不再有php5isapi.dll这个文件。要在IIS6上使用高版本PHP,必须安装FastCGI 扩展,然后使IIS6支持FastCGI。故此处不做过多介绍

图解:
认识PHP运行模式_第4张图片

写在最后:

在互联网爆炸式发展的今天,绝大多数网站都需要考虑网站的高并发性能。Nginx由于其轻量和出色的并发性能等优点,越来越多的受到开发者的青睐。曾经火爆全网的 LAMP 组合已不是PHP开发者的第一选择,异军突起的 LNMP 组合已然成为 PHPer 的必修课,这导致基于 Apache 的LoadModule模式已越来越少被提及。
除此以外,用来写命令行脚本CLI模式和几乎绝迹的 ISAPI 模式显然不适合建设网站。
作为 CGI 加强版的 Fast-CGI 模式在继承了 CGI 简单、安全的基础上,使用PHP-FPM管理子进程,使得web服务器更加专注的处理I/O,PHP-FPM管理维护一个进程池,可提前 fork 一定数量的子进程等待处理请求,既不用在请求到来时才fork子进程,也不用在请求结束时就销毁子进程

你可能感兴趣的:(认识PHP)