搞不清FastCgi与PHP-fpm之间是个什么样的关系?

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

web server(比如说nginx)只是内容的分发者。比如,如果请求/index.html,那么web server会去文件系统中找到这个文件,发送给浏览器,这里分发的是静态数据。好了,如果现在请求的是/index.php,根据配置文件,nginx知道这个不是静态文件,需要去找PHP解析器来处理,那么他会把这个请求简单处理后交给PHP解析器。Nginx会传哪些数据给PHP解析器呢?url要有吧,查询字符串也得有吧,POST数据也要有,HTTP header不能少吧,好的,CGI就是规定要传哪些数据、以什么样的格式传递给后方处理这个请求的协议。仔细想想,你在PHP代码中使用的用户从哪里来的。

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

好了,CGI是个协议,跟进程什么的没关系。那fastcgi又是什么呢?Fastcgi是用来提高CGI程序性能的。

提高性能,那么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也是这么个东东,在长时间的发展后,逐渐得到了大家的认可(要知道,前几年大家可是抱怨PHP-FPM稳定性太差的),也越来越流行。


好了,最后来回来你的问题。
网上有的说,fastcgi是一个协议,php-fpm实现了这个协议

对。

有的说,php-fpm是fastcgi进程的管理器,用来管理fastcgi进程的

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

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

有的说,修改了php.ini配置文件后,没办法平滑重启,所以就诞生了php-fpm

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

还有的说PHP-CGI是PHP自带的FastCGI管理器,那这样的话干吗又弄个php-fpm出

不对。php-cgi只是解释PHP脚本的程序而已。


php-cgi是fastcgi 的进程管理器,php-fpm 也是fastcgi的进程管理器,那么php-fpm和php-cgi 有什么关系呢?

baitercel:php-fpm是一个进程池,然后调用php-cgi进程吗,还是php-fpm和php-cgi 没有任何关系,php-fpm和php-cgi都是调用fastcgi进程

SyuTingSong:@baitercel 没有任何关系,php-fpm和php-cgi都链接了php解释器,彼此没有相互依赖

baitercel:@SyuTingSong 那,php的解释器是什么呢,php的解释器不是php-cgi吗

SyuTingSong:@baitercel 不是的,PHP里把解释器分解成许多模块,php、php-cgi、php-fpm只是入口

baitercel:@SyuTingSong 明白了 ,谢谢.

SyuTingSong:@baitercel 我看了一下我服务器上的php7.0的程序,解释器应该是静态链接进去的,php、php-cgi、php-fpm都有41M那么大,应该包括完整的php解释器内核了。

王航:终于明白了,记个笔记。
在php-cgi模式下,如果更改了配置文件,只能kill掉当前进程,然后再重新启用,这里边存在一个问题,如果网站并发特别大,每刻都有请求连接,那这样就可能会造成用户的操作异常。
php-fpm的热加载和nginx原理应该一样,就是说收到信号的话,先kill掉空闲worker进程,这时候正在处理连接的子进程继续处理请求,请求结束退出操作。然后master进程会重新拉起新的worker进程。


参考1 参考2

总结FastCgi与PHP-FPM之间的关系 PHP-CGI与PHP-FPM之间是关系相关推荐

  1. python中对象和类的关系_Python面向对象之类与类之间的关系

    2.2 关联,聚合,组合关系 其实这三个在代码上写法是⼀样的. 但是, 从含义上是不⼀样的. 1. 关联关系. 两种事物必须是互相关联的. 但是在某些特殊情况下是可以更改和更换的. 2. 聚合关系. ...

  2. IT项目管理中projects、programs和portfolio之间的关系,附带operations以及OPM之间的关系分析

    Projects.programs.portfolio.operations以及OPM概念 projects(项目):项目是一个特殊的.将被完 成的有限任务,它是在一定时间内,满足一系列特定目标的 多 ...

  3. 【数字信号处理】基本序列 ( 单位阶跃序列 | 单位阶跃序列与单位脉冲序列关系 | 矩形序列 | 矩形序列与单位阶跃序列关系 | 矩形序列作用 )

    文章目录 一.单位阶跃序列 1.单位阶跃序列与单位脉冲序列关系 二.矩形序列 1.矩形序列与单位阶跃序列关系 2.矩形序列作用 一.单位阶跃序列 单位阶跃序列 : u(n)={1n≥00n<0u ...

  4. Exploiting the Syntax-Model Consistency for Neural Relation Extraction(关系抽取,语法模型,跨领域关系抽取

    文章目录 1.Introductiony 1.1 神经网络的关系抽取 1.2使用依赖树的关系抽取 1.2.2 依赖树的一般树 1.3 本文做法 2. 相关工作 2.1核方法 2.2 深度学习方法 2. ...

  5. 离散数学知识点总结(10)“关系” 知识的总结 <1>:关系的基础概念 —— 有序 n 元组,集合的笛卡尔积,集合的关系(二元关系)的定义,关系的集合运算, 关系的基本性质

    文章目录 有序 n 元组和集合的笛卡尔积 序偶关系 有序二元组 序偶相等 有序三元组 有序n元组 有序 n 元组相等 集合的笛卡尔积 集合笛卡尔积的性质 集合的二元关系及其表示方法 相关 关系的定义 ...

  6. 计算机和学生的关系的英语作文,学生和老师的关系的英文作文

    关于"学生和老师的关系"的英语作文模板2篇,作文题目:The relationship between students and teachers.以下是关于学生和老师的关系的四级 ...

  7. mysql学生选课系统的关系模型_数据库系统原理ER模型与关系模型

    数据库系统是软件的一种,数据库系统自然而然也有他自己的生命周期生存期.它的生存期从规划开始,一直到将它卸载不用了.它的中间过程很复杂,为了实现用户的想法,数据库有关人员将现实生活中的数据进行抽象,然后 ...

  8. 1000-2000年之间闰年年份、个数以及任意年份之间的闰年年份、个数

    1000-2000年之间闰年年份.个数以及任意年份之间的闰年年份.个数 初学C语言的过程中,经常会遇到求年份之间的闰年年份以及总个数,今天就以1000-2000年之间闰年年份.个数为例. Q:求100 ...

  9. 两性关系心理学:探讨魅力点和感觉的关系

    目录标题 前言 特性解释 "魅力点" 总结 前言 在人类社会中,爱情和恋爱一直是一个广受关注的话题.我们都希望自己能够吸引到异性的注意和喜欢,但是如何做到这一点却是一个比较复杂的问 ...

  10. MySQL的关系模式集是什么,[转载]数据库的关系模型、关系模式、主码。。。。...

    1.关系模型:用二维表格结构表示实体集,外键表示实体间联系的数据模型称为关系模型.关系模型是由若干个关系模式组成的集合. 2.关系模式:关系模式实际上就是记录类型.它包括:模式名,属性名,值 ... ...

最新文章

  1. java求最小步数,使数组值相等的最小步数 Minimum Moves to Equal Array Elements
  2. [JavaME]解决来电问题(Incoming Call)
  3. 深入分析 Java 中的中文编码问题--转
  4. HTTP:HTTP的server and client详细攻略
  5. 大数据技术在跨境电商中的应用
  6. .Net(c#)加密解密之Aes和Des
  7. 三周的 软件工程实践课 课程安排建议
  8. Oracle BBED 工具介绍
  9. pyqt,Qt Designer 界面布局子窗口可移动
  10. gitlab用户,组,项目权限管控
  11. linux模板机配置文件,制作Centos 7.4操作系统模板机
  12. JavaScript面向对象之构造函数
  13. 【深度学习案例】手写数字项目实现-1.数据集介绍
  14. 将VSCode添加到鼠标右键菜单
  15. Ubuntu 开机自动运行命令或程序
  16. 常见web漏洞修复方法
  17. 【Python面向对象编程】第19篇 只读属性
  18. Java基础恶补——内存泄露、内存溢出
  19. 解决杜比视界(Dolby Vision)版本高清片源颜色不正问题
  20. 如何学好c++,还是好好看书籍吧!

热门文章

  1. Typescript 中 ?问号的几种不同用法
  2. UI一揽子计划 19 (数据库管理系统、SQL语句、iOS 的数据库实现技术)
  3. YouTube 全球范围宕机事件,华为回应荣耀单飞
  4. 《网络安全》第1章部分作业解答
  5. Docker容器 - 虚悬镜像
  6. SQLSUM函数的使用
  7. iOS证书即将过期的更新步骤
  8. eclipse快捷键大全,让敲代码更快一点
  9. 730.所有子集的和
  10. 代码发芽网:无需插件支持Blog代码高亮,支持近百种编程语言