cgi是一個協(xié)議,它規(guī)定了服務器Nginx會將那些數(shù)據(jù)傳送給php-cgi
fastcgi也可以說是一個協(xié)議伦乔。fastcgi是對cgi的性能的一次提高勇吊。fastcgi會先啟動一個master辫愉,解析配置文件(php.ini等)署辉,初始化執(zhí)行環(huán)境,然后再啟動多個worker岩四,當請求過來時哭尝,master會傳遞給一個worker,然后等待下一個請求剖煌。
php-fpm是實現(xiàn)了fastcgi這個協(xié)議的程序材鹦,用來管理php-cgi的(php-fpm是fastcgi進程管理器)
php-cgi是解釋php程序的
剛開始對這個問題我也挺糾結的,看了《HTTP權威指南》后耕姊,感覺清晰了不少桶唐。
首先,CGI是干嘛的茉兰?CGI是為了保證web server傳遞過來的數(shù)據(jù)是標準格式的尤泽,方便CGI程序的編寫者。
web server(比如說nginx)只是內(nèi)容的分發(fā)者规脸。比如坯约,如果請求/index.html,那么web server會去文件系統(tǒng)中找到這個文件莫鸭,發(fā)送給瀏覽器闹丐,這里分發(fā)的是靜態(tài)數(shù)據(jù)。好了被因,如果現(xiàn)在請求的是/index.php卿拴,根據(jù)配置文件,nginx知道這個不是靜態(tài)文件梨与,需要去找PHP解析器來處理堕花,那么他會把這個請求簡單處理后交給PHP解析器。Nginx會傳哪些數(shù)據(jù)給PHP解析器呢粥鞋?url要有吧航徙,查詢字符串也得有吧,POST數(shù)據(jù)也要有,HTTP header不能少吧到踏,好的杠袱,CGI就是規(guī)定要傳哪些數(shù)據(jù)、以什么樣的格式傳遞給后方處理這個請求的協(xié)議窝稿。仔細想想楣富,你在PHP代碼中使用的用戶從哪里來的。
當web server收到/index.php
這個請求后伴榔,會啟動對應的CGI程序纹蝴,這里就是PHP的解析器。接下來PHP解析器會解析php.ini文件踪少,初始化執(zhí)行環(huán)境塘安,然后處理請求,再以規(guī)定CGI規(guī)定的格式返回處理后的結果援奢,退出進程兼犯。web server再把結果返回給瀏覽器。
好了集漾,CGI是個協(xié)議切黔,跟進程什么的沒關系。那fastcgi又是什么呢具篇?Fastcgi是用來提高CGI程序性能的纬霞。
提高性能,那么CGI程序的性能問題在哪呢驱显?"PHP解析器會解析php.ini文件诗芜,初始化執(zhí)行環(huán)境",就是這里了埃疫。標準的CGI對每個請求都會執(zhí)行這些步驟(不閑累熬钅啊!啟動進程很累的說H刍帧)脐湾,所以處理每個時間的時間會比較長。這明顯不合理嘛叙淌!那么Fastcgi是怎么做的呢秤掌?首先,F(xiàn)astcgi會先啟一個master鹰霍,解析配置文件闻鉴,初始化執(zhí)行環(huán)境,然后再啟動多個worker茂洒。當請求過來時孟岛,master會傳遞給一個worker,然后立即可以接受下一個請求。這樣就避免了重復的勞動渠羞,效率自然是高斤贰。而且當worker不夠用時,master可以根據(jù)配置預先啟動幾個worker等著次询;當然空閑worker太多時荧恍,也會停掉一些,這樣就提高了性能屯吊,也節(jié)約了資源送巡。這就是fastcgi的對進程的管理。
那PHP-FPM又是什么呢盒卸?是一個實現(xiàn)了Fastcgi的程序骗爆,被PHP官方收了。
大家都知道蔽介,PHP的解釋器是php-cgi摘投。php-cgi只是個CGI程序,他自己本身只能解析請求屉佳,返回結果谷朝,不會進程管理(皇上洲押,臣妾真的做不到拔浠ā!)所以就出現(xiàn)了一些能夠調度php-cgi進程的程序杈帐,比如說由lighthttpd分離出來的spawn-fcgi体箕。好了PHP-FPM也是這么個東東,在長時間的發(fā)展后挑童,逐漸得到了大家的認可(要知道累铅,前幾年大家可是抱怨PHP-FPM穩(wěn)定性太差的),也越來越流行站叼。
網(wǎng)上有的說娃兽,fastcgi是一個協(xié)議,php-fpm實現(xiàn)了這個協(xié)議
對尽楔。
有的說投储,php-fpm是fastcgi進程的管理器,用來管理fastcgi進程的
對阔馋。php-fpm的管理對象是php-cgi玛荞。但不能說php-fpm是fastcgi進程的管理器,因為前面說了fastcgi是個協(xié)議呕寝,似乎沒有這么個進程存在勋眯,就算存在php-fpm也管理不了他(至少目前是)。 有的說,php-fpm是php內(nèi)核的一個補丁
以前是對的客蹋。因為最開始的時候php-fpm沒有包含在PHP內(nèi)核里面塞蹭,要使用這個功能,需要找到與源碼版本相同的php-fpm對內(nèi)核打補丁嚼酝,然后再編譯浮还。后來PHP內(nèi)核集成了PHP-FPM之后就方便多了,使用--enalbe-fpm這個編譯參數(shù)即可闽巩。
有的說钧舌,修改了php.ini配置文件后,沒辦法平滑重啟涎跨,所以就誕生了php-fpm
是的洼冻,修改php.ini之后,php-cgi進程的確是沒辦法平滑重啟的隅很。php-fpm對此的處理機制是新的worker用新的配置撞牢,已經(jīng)存在的worker處理完手上的活就可以歇著了,通過這種機制來平滑過度叔营。
還有的說PHP-CGI是PHP自帶的FastCGI管理器屋彪,那這樣的話干嗎又弄個php-fpm出
不對。php-cgi只是解釋PHP腳本的程序而已绒尊。