您好,登錄后才能下訂單哦!
一,cgi和fastcgi
在將php-fpm工作原理時,需要先明白cgi是什么?
cgi是使web server和后臺語言進行交互的協議,有了這個協議,開發者可以使用任何語言處理Web server發來的請求,動態生成內容。單CGI有一個致命的缺點,那就是每處理一個請求都需要fork一個全新的進程,隨著Web的興起,高并發越來越成為常態,這樣的低效方式明顯不能滿足需求。這樣,fastcgi就誕生了,cgi很快的退出了歷史舞臺,Fastcgi,顧名思義為更快的CGI,它允許在一個進程內處理多個請求,而不是一個請求處理完畢就直接結束進程,性能上有了很大的提高。
至于 FPM (FastCGI Process Manager),它是 FastCGI 的實現,任何實現了 FastCGI 協議的 Web Server 都能夠與之通信。FPM 之于標準的 FastCGI,也提供了一些增強功能。
FPM 是一個 PHP 進程管理器,包含 master 進程和 worker 進程兩種進程:master 進程只有一個,負責監聽端口,接收來自 Web Server 的請求,而 worker 進程則一般有多個 (具體數量根據實際需要配置),每個進程內部都嵌入了一個 PHP 解釋器,是 PHP 代碼真正執行的地方,下圖是我本機上 fpm 的進程情況,1一個 master 進程,3個 worker 進程:
從 FPM 接收到請求,到處理完畢,其具體的流程如下:
FPM 的 master 進程接收到請求
master 進程根據配置指派特定的 worker 進程進行請求處理,如果沒有可用進程,返回錯誤,這也是我們配合 Nginx 遇到502錯誤比較多的原因。
worker 進程處理請求,如果超時,返回504錯誤
請求處理結束,返回結果
FPM 從接收到處理請求的流程就是這樣了,那么 Nginx 又是如何發送請求給 fpm 的呢?這就需要從 Nginx 層面來說明了。
我們知道,Nginx 不僅僅是一個 Web 服務器,也是一個功能強大的 Proxy 服務器,除了進行 http 請求的代理,也可以進行許多其他協議請求的代理,包括本文與 fpm 相關的 fastcgi 協議。為了能夠使 Nginx 理解 fastcgi 協議,Nginx 提供了 fastcgi 模塊來將 http 請求映射為對應的 fastcgi 請求。
Nginx 的 fastcgi 模塊提供了 fastcgi_param 指令來主要處理這些映射關系,下面 Ubuntu 下 Nginx 的一個配置文件,其主要完成的工作是將 Nginx 中的變量翻譯成 PHP 中能夠理解的變量。
除此之外,非常重要的就是 fastcgi_pass 指令了,這個指令用于指定 fpm 進程監聽的地址,Nginx 會把所有的 php 請求翻譯成 fastcgi 請求之后再發送到這個地址。下面一個簡單的可以工作的 Nginx 配置文件:
在這個配置文件中,我們新建了一個虛擬主機,監聽在 80 端口,Web 根目錄為 /home/rf/projects/wordpress。然后我們通過 location 指令,將所有的以 .php 結尾的請求都交給 fastcgi 模塊處理,從而把所有的 php 請求都交給了 fpm 處理,從而完成 Nginx 到 fpm 的閉環。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。