先说下我最近看到的一篇文章,哈哈哈,特别好玩。php
以前一直知道 PHP 在 CGI 模式下运行。命令行下在 CLI 模式下运行。nginx
可是 FPM 和 nginx 配置 FastCGI 他们具体是什么关系?还真的不太明白,今天来讲下他们的关系。web
CGI 是干什么的?segmentfault
这得和咱们的一个请求的正常流程来看。浏览器
当一个请求来时,由 WebServer(nginx/Apache) 来对请求进行分发。服务器
若是请求的是 index.html 那么服务器回去寻找对应的文件并返回该静态资源。php-fpm
固然,这只是静态资源。性能
当请求内容为 index.php 时,WebServer 发现这并非一个静态文件,以后会根据配置来寻找 PHP 解析器来处理这个请求。spa
找到 PHP 解析器以后,怎么传递数据呢?必须使用你们都明白的的一个东西吧,就像 英语 -> 英语交流, 汉语->汉语交流,英语->汉语->没法交流(不明白对方说的什么);
CGI就是规定要传哪些数据、以什么样的格式传递给后方处理这个请求的协议。仔细想一想,你在PHP代码中全部的数据是怎么来的?
因此,当收到 /index.php 这个请求后
1:会启动CGI程序【PHP解释器】。
2:以后CGI会启动一个进程解析 php.ini ,初始环境,处理请求。
3:在已规定规定好的CGI格式返回给 WebServer 。
4:销毁这个进程。
5:WebServer 在把结果返回给浏览器。
CGI是个协议,是为了保证web server传递过来的数据是标准格式的
Fastcgi 是干什么的?
这里就须要说一下 PHP-CGI 的缺点了,经过上面关于CGI的描述,发现 CGI 的特色
请求->启动一个进程处理->处理完销毁这个进程
CGI在请求时反复加载,这也正是 CGI 性能低下的主要缘由,正是应为这样,才有了Fastcgi。
定义:WEB服务器与处理程序之间通讯的一种协议,是CGI的改进方案。
不一样【也能够说是特色吧】:
1:fastcgi 是一个常驻型的CGI,能够一直运行,在请求时,不会fock一个新的进程来处理。
2:CGI 解释器进程在内存中保持,以此来得到更好的性能。
Fastcgi 工做流程:
1:在Web Server启动时同时载入 Fastcgi 进程管理器
2:Fastcgi进程管理器自身初始化,启动多个CGI解释器进程(可见多个php-cgi)并等待WebServer的链接
3:当客户端请求到达Web Server时,FastCGI进程管理器选择并链接到一个CGI解释器。 Web server将CGI环境变量和标准输入发送到FastCGI子进程php-cgi。
4:FastCGI子进程完成处理后将标准输出和错误信息从同一链接返回Web Server。当FastCGI子进程关闭链接时,请求便告处理完成。
5: FastCGI子进程接着等待并处理来自FastCGI进程管理器(运行在Web Server中)的下一个链接。在CGI模式中,php-cgi在此便退出了。
简单来讲:
好比我家要装修,装修材料不知道何时来。
CGI是:
装修材料来->雇工人->干活->解雇工人。
费时费力。
Fastcgi:
先雇几个工人等着->无论何时材料来->干活->继续等着
总结:Fastcgi就是用来提升CGI程序性能的。
PHP-FPM 是干什么的?
Fastcgi 比 CGI 好用,咱们为何不用,因而 被PHP官方收了。
你们都知道,PHP解释器是PHP-CGI,可是PHP-CGI是个CGI程序,本身自己只能解析请求,并不能对进程进行管理。
因此就出现了一些能够管理 PHP-CGI 进程的程序。
PHP-FPM 也就是这样。
总结:php-fpm是fastcgi进程的管理器,用来管理fastcgi进程的
总结:
fastcgi是一个协议,php-fpm实现了这个协议。
php-fpm的管理对象是php-cgi。但不能说php-fpm是fastcgi进程的管理器,由于前面说了fastcgi是个协议,彷佛没有这么个进程存在,就算存在php-fpm也管理不了他(至少目前是).
参考: