fastcgi php-cgi與php-fpm區別和之間的關系


關於FastCGI、php-cgi、php-fpm的區別是什么,各自有什么用途,以及相互間的關系是什么,查閱相關資料,可謂是眾說紛紜,莫衷一是:

說法一:fastcgi是一個協議,php-fpm實現了這個協議;

說法二:php-fpm是FASTCGI進程的管理器,用來管理fastcgi進程的;

說法三:php-fpm是php內核的一個補丁;

說法四:修改了php.ini配置文件后,沒辦法平滑重啟,所以就誕生了php-fpm;

說法五:php-cgi是php自帶的FASTCGI管理器;

......

筆者在學習PHP時也曾有過這個困惑,也曾翻閱了很多資料,最近在交流過過程中,發現很多伙伴還是無法弄其作用和之間的聯系,所以寫下此文,拋磚引玉。

首先要了解的是CGI

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的升級版,一種語言無關的協議,FastCGI是用來提高CGI程序性能的(從字面意思來能好理解)

標准的CGI對每個請求都會執行這些步驟(不閑累啊!啟動進程很累的說!),所以處理每個時間的時間會比較長。這明顯不合理嘛!那么FastCGI是怎么做的呢?首先,FastCGI會先啟一個master,解析配置文件,初始化執行環境,然后再啟動多個worker。當請求過來時,master會傳遞給一個worker,然后立即可以接受下一個請求。這樣就避免了重復的勞動,效率自然是高。而且當worker不夠用時,master可以根據配置預先啟動幾個worker等着;當然空閑worker太多時,也會停掉一些,這樣就提高了性能,也節約了資源。這就是"FastCGI"的對進程的管理(先姑且這么說)

php-fpm是什么?

是一個實現了FastCGI(協議)的程序

大家都知道,PHP的解釋器是php-cgi。php-cgi只是個CGI程序,他自己本身只能解析請求,返回結果,不會管理進程,所以就出現了一些能夠調度php-cgi進程的程序,比如說由lighthttpd分離出來的spawn-fcgi。好了php-fpm也是這么個東西,在長時間的發展后,逐漸得到了大家的認可,也越來越流行。

php-fpm的管理對象是php-cgi,但不能說php-fpm是FastCGI進程的管理器,因為前面說了FastCGI是個協議,似乎沒有這么個進程存在,就算存在php-fpm也管理不了他(至少目前是)。他負責管理一個進程池,來處理來自Web服務器的請求。

php-fpm是PHP內核的一個補丁? 以前是正確的,因為最開始的時候php-fpm沒有包含在PHP內核里面,要使用這個功能,需要找到與源碼版本相同的php-fpm對內核打補丁,然后再編譯。后來PHP(5.3以后)內核集成了php-fpm,編譯時加上--enalbe-fpm這個參數即可。

對於php.ini文件的修改,php-cgi進程是沒辦法平滑重啟的,有了php-fpm后,就把平滑重啟成為了一種可能,php-fpm對此的處理機制是新的worker用新的配置,已經存在的worker處理完手上的活就可以歇着了,通過這種機制來平滑過度的。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM