Nginx解析PHP脚本的过程

1、什么是CGI

CGI是Common Gateway Interface(公共网关接口)的缩写,它有什么用呢?我们知道浏览器访问一个含有动态数据的页面,浏览器使用HTTP协议发送请求。数据包经过路由器和交换机,到达目标web服务器,web服务器收到这个请求,需要和PHP通信,才能拿到含有动态数据的页面。为什么要通信?因为他们语言不通(nginx等web服务器和php语言和语法不一样,没法直接沟通)

那么,要怎么通信呢?最早是用CGI协议来通信。通过CGI协议,nginx能够将HTTP请求转化为PHP可以理解的语言(uri,post数据和get的数据,HTTP header等数据)。CGI规定了要传哪些数据、以什么样的格式传递给后方处理。

1、传统的使用CGI协议的工作方式

web服务器本身只是内容的分发者,比如请求/index.html,web服务器就会去寻找这个文件,然后返回给浏览器,这里指的只是静态文件。如果是请求/index.php会怎么样?web服务器知道这不是个静态资源,需要解析后再返回给浏览器,于是web服务器就启动一个php解释器进程,这个解释器实现了CGI协议,能够完成和后端语言PHP的沟通,PHP把该返回的动态数据还给web服务器,然后web服务器再发给浏览器。

2、传统的CGI协议的弊端

为什么传统的CGI工作方式会有弊端?因为每请求一个PHP脚本,web服务器就得为一个请求开启一个PHP解释器(早期是php-cgi)进程来完成解析。这意味着:每来一个请求,解释器就得初始化php.ini并加载php扩展,等环境初始化完了,再解析,解析完成后进程自动结束(即fork-and-execute模式)。

所以用cgi方式的服务器有多少连接请求就会有多少cgi子进程,子进程反复加载是cgi性能低下的主要原因。都会当用户请求数量非常多时,会大量挤占系统的资源如内 存,CPU时间等,造成效能低下。

2、什么是fastCGI

fastCGI,通俗的翻译为快速的CGI。FastCGI,顾名思义为更快的 CGI,它允许在一个进程内处理多个请求,而不是一个请求处理完毕就直接结束进程,web服务器性能上有了很大的提高。

1、关于php-fpm

php-fpm,即专门为php打造的fastCGI process manager(PHP的fastCGI管理器)。nginx使用这些php-fpm进程来和PHP进行通信,你可以理解把php-fpm理解为php解释器。

和传统的php-cgi的解释器不同,php-fpm实现了fastCGI协议,而且还新增了不少特性。比如php-fpm能够平滑重启php环境配置:我们知道在修改了php.ini之后,wamp和phpstudy需要重启服务器才能重新加载php.ini里的内容。如果是php-fpm,则不用重启web服务器,原先正在工作的php-fpm继续工作,等原先工作的php-fpm完成自己的工作后,就结束掉自己。新增加的php-fpm就使用修改后的php.ini即可。

2、实现了fastCGI的工作方式

实现了fastCGI协议的nginx,第一次启动时,会启动一个php-fpm的master进程,该master进程初始化环境后,启动多个worker进程(即php-fpm进程池中的php-fpm),如下图:

当请求发来后,master进程把请求分发到进程池中的php-fpm,分发完后,就可以接下一个请求了,避免了重复劳动(重复加载php.ini初始化环境),效率自然提升了。当请求多的时候,master会启动更多的php-fpm子进程,当请求少的时候,master也会停掉一些子进程。既提高了性能,也节省资源。

当然,当php-fpm设定的上限,不足以支持更高的并发请求时,nginx只能返回502错误了,因为没有更多的php-fpm进程可用了。

在这种协议下,php-fpm成为了和PHP沟通的PHP解释器。

3、nginx是如何和php-fpm进程交流的

到目前为止,我们知道了实现了fastCGI的php-fpm是如何工作的,但是nginx是怎么启动php-fpm进程的呢?

Nginx 不仅仅是一个 Web 服务器,也是一个功能强大的 Proxy 服务器,除了进行 http 请求的代理,也可以进行许多其他协议请求的代理,包括本文与 fpm 相关的 fastcgi 协议。为了能够使 Nginx 理解 fastcgi 协议,Nginx 提供了 fastcgi 模块来将 http 请求映射为对应的 fastcgi 请求。

下面是一个nginx的配置文件,用来把nginx中的变量,解释为PHP能够理解的变量:

下面是nginx把php请求交给fastCGI模块来处理的配置(在nginx.conf中可以查到此项配置)

在这个配置文件中,我们新建了一个虚拟主机,监听在 80 端口,Web 根目录为 /home/rf/projects/wordpress。通过location配置,我们把所有.php文件的处理,交给了fastCGI模块。之后就是fastCGI模块启动php-fpm(实现fastCGI模块),并通过php-fpm来解释动态请求。

下面是我总结的一个流程图,如果有不正确的地方,欢迎指正。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342

推荐阅读更多精彩内容