首頁  >  文章  >  後端開發  >  五大PHP運行模式

五大PHP運行模式

小云云
小云云原創
2018-03-22 13:16:132048瀏覽

關於PHP目前較常見的五大運轉模式有CGI(通用閘道介面/ Common Gateway Interface)、FastCGI(常駐型CGI / Long-Live CGI )、CLI(命令列運作 / Command Line Interface)、Web模組模式(Apache等Web伺服器運作的模式) 、ISAPI(Internet Server Application Program Interface),希望本文能幫助大家。

備註:在PHP5.3以後,PHP不再有ISAPI模式,安裝後也不再有php5isapi.dll這個檔案。要在IIS6上使用高版本PHP,必須安裝FastCGI 擴展,然後使IIS6支援FastCGI。

1.1、CGI模式

#CGI即通用網關介面(Common Gateway Interface),它是一段程序,通俗的講CGI就像是一座橋,把網頁和Web伺服器中的執行程序連接起來,它把HTML接收的指令傳遞給伺服器的執行程序,再把伺服器執行程式的結果回饋給HTML頁。 CGI 的跨平台效能極佳,幾乎可以在任何作業系統上實現。 CGI已經是比較老的模式了,這幾年都很少用了。 

   每有一個使用者請求,都會先建立CGI的子進程,然後處理請求,處理完後結束這個子進程,這就是Fork-And-Execute模式。 當使用者請求數量非常多時,會大量擠佔系統的資源如內存,CPU時間等,造成效能低落。所以用CGI方式的伺服器有多少連線請求就會有多少CGI子進程,子進程反覆載入是CGI效能低下的主要原因。 

   如果不想將 PHP 嵌入伺服器端軟體(如 Apache)作為一個模組安裝的話,可以選擇以 CGI 的模式安裝。或將 PHP 用於不同的 CGI 封裝以便為程式碼建立安全的 chroot 和 setuid 環境。這樣每個客戶機請求一個PHP文件,Web伺服器就呼叫php.exe(win下是php.exe,linux是php)去解釋這個文件,然後再把解釋的結果以網頁的形式傳回給客戶機。 這種安裝方式通常會將 PHP 的執行檔安裝到 web 伺服器的 cgi-bin 目錄。 CERT 建議書 CA-96.11 建議不要把任何的解釋器放到 cgi-bin 目錄。這種方式的好處是把Web Server和具體的程式處理獨立開來,結構清晰,可控性強,同時缺點就是如果在高存取需求的情況下,CGI的進程Fork就會成為很大的伺服器負擔,想 像數百個並發請求導致伺服器Fork出數百個進程就明白了。這也是為什麼CGI一直背負著表現低下,高資源消耗的惡名的原因。

1.2、FastCGI模式

FastCGI是CGI的升級版本,FastCGI像是常駐 (long-live)型的 CGI,它可以一直執行著,只要啟動後,不會每次都要花時間去 Fork 一次 (這是 CGI 最為人詬病的 fork-and-execute 模式)。 

FastCGI是一個可伸縮地、高速地在HTTP server和動態腳本語言間溝通的介面。多數流行的HTTP server都支持FastCGI,包括Apache、Nginx和lighttpd等,同時,FastCGI也被許多腳本語言所支持,其中就有PHP。 

FastCGI介面方式採用C/S結構,可以將HTTP伺服器和腳本解析伺服器分開,同時在腳本解析伺服器上啟動一個或多個腳本解析守護程式。當HTTP伺服器每次遇到動態程式時,可以直接交付給FastCGI進程來執行,然後將得到的結果傳回瀏覽器。這種方式可以讓HTTP伺服器專一地處理靜態請求或將動態腳本伺服器的結果傳回給客戶端,這在很大程度上提高了整個應用系統的效能。  

【原理】 

1)Web Server啟動時載入FastCGI進程管理器(IIS ISAPI或Apache Module); 

#2)FastCGI進程管理器本身初始化,啟動多個CGI解釋器進程 (可見多個php-cgi.exe或php-cig)並等待來自Web Server的連接; 

3)當客戶端請求到達Web Server時,FastCGI進程管理器選擇並連接到一個CGI解釋器。 Web server將CGI環境變數和標準輸入傳送至FastCGI子進程php-cgi; 

4)FastCGI子進程完成處理後將標準輸出和錯誤訊息從相同連線傳回Web Server。當FastCGI子程序關閉連線時,請求便告處理完成。 FastCGI子進程接著等待並處理來自FastCGI進程管理器(運行在 WebServer中)的下一個連線。在正常的CGI模式中,php-cgi.exe在此便退出了。 

   在CGI模式中,你可以想像 CGI通常有多慢。每一個Web請求PHP都必須重新解析php.ini、重新載入全部dll擴充並重初始化全部資料結構。使用FastCGI,所有這些都只在進程啟動時發生一次。一個額外的好處是,持續資料庫連線(Persistent database connection)可以運作。

 

備註:PHP的FastCGI進程管理器是PHP-FPM(PHP-FastCGI Process Manager)   

#【優點】 

1)從穩定性上看,FastCGI是以獨立的進程池來運行CGI,單獨一個進程死掉,系統可以很輕易的丟棄,然後重新分配新的進程來運行邏輯; 

2)從安全性上看,FastCGI支援分散式運算。 FastCGI和宿主的Server完全獨立,FastCGI怎麼down也不會把Server搞垮; 

#3)從性能上看,FastCGI把動態邏輯的處理從Server中分離出來,大負載的IO處理還是留給宿主Server,這樣宿主Server可以一心一意作IO,對於一個普通的動態網頁來說, 邏輯處理可能只有一小部分,大量的是圖片等靜態。   

【缺點】 

   說完了好處,也來說說缺點。從我的實際使用來看,用FastCGI模式比較適合生產環境的伺服器。但對於開發用機器來說就不太適合。因為使用 Zend Studio調試程式時,由於 FastCGI會認為 PHP進程逾時,因此在頁面回傳 500錯誤。這一點讓人非常惱火,所以我在開發機器上還是換回了 ISAPI模式。對某些伺服器的新版本支援不好,對分散式負載平衡沒要求的模組化安裝是否是更好的選擇。目前的FastCGI和Server溝通還不夠智能,一個FastCGI進程如果執行時間過長會被當成是死進程殺掉重起,這樣在處理長時間任務的時候很麻煩,這樣做也使得FastCGI無法允許聯機調試。因為是多進程,所以比CGI多線程消耗更多的伺服器內存,PHP-CGI解釋器每進程消耗7至25兆內存,將這個數字乘以50或100就是很大的內存數。

1.3 CLI模式 

#   PHP-CLI是PHP Command Line Interface的簡稱,如同它名字的意思,就是PHP在命令列上執行的接口,區別於在Web伺服器上運行的PHP環境(PHP-CGI,ISAPI等)。 也就是說,PHP不單可以寫前台網頁,它也可以用來寫後台的程式。 PHP的CLI Shell腳本適用於所有的PHP優勢,使創建要麼支援腳本或系統甚至與GUI應用程式的服務端,在Windows和Linux下都是支援PHP-CLI模式的。

【優點】 

1)使用多進程,子進程結束以後,核心會負責回收資源; 

2)使用多進程,子進程異常退出不會導致整個行程Thread退出,父行程還有機會重建流程一個常駐主流程,只負責任務分發,邏輯更清楚; 

#

3)可以實作定時任務,linux下用php寫shell腳本。 

   我們在Linux下經常使用"php –m"查找PHP安裝了那些擴展就是PHP命令列運行模式;有興趣的同學可以輸入"php –h"去深入研究該運行模式。

1.4 模組模式 

#   模組模式是以mod_php5模組的形式集成,此時mod_php5模組的作用是接收Apache傳遞過來的PHP文件請求,並處理這些請求,然後將處理後的結果傳回給Apache。如果我們在Apache啟動前在其設定檔中設定好了PHP模組

(mod_php5), PHP模組透過註冊apache2的ap_hook_post_config掛鉤,在Apache啟動的時候啟動此模組以接受PHP檔案的請求。

   除了這種啟動時的載入方式,Apache的模組可以在運行的時候動態裝載,這意味著對伺服器可以進行功能擴展而不需要重新對原始碼進行編譯,甚至根本不需要停止伺服器.我們所需要做的只是給伺服器發送訊號HUP或AP_SIG_GRACEFUL通知伺服器重新載入模組。但是在動態載入之前,我們需要將模組編譯成為動態連結函式庫。此時的動態載入就是載入動態連結庫。 Apache中對動態連結函式庫的處理是透過模組mod_so來完成的,因此mod_so模組不能被動態載入,它只能被靜態編譯進Apache的核心。這意味著它是隨著Apache一起啟動的。 

   Apache是​​如何載入模組的呢?我們以前面提到的mod_php5模組為例。首先我們需要在Apache的設定檔httpd.conf中加入一行:

LoadModule php5_module modules/mod_php5.so 

   這裡我們使用了LoadModule指令,而這個指令的第一個參數是模組的名稱,名稱可以在模組實現的源碼中找到。第二個選項是該模組所處的路徑。如果需要在伺服器執行時間載入模組,可以透過發送訊號HUP或AP_SIG_GRACEFUL給伺服器,一旦接受到該訊號,Apache將重新裝載模組,而不需要重新啟動伺服器。 

   這個運作模式是我們先前在windows環境下使用apache伺服器經常使用的,而在模組化(DLL)中,PHP是與Web伺服器一起啟動並運行的。 (它是apache在CGI的基礎上進行的一種擴展,加快PHP的運作效率)。

1.5 ISAPI模式 

#   ISAPI(Internet Server Application Program Interface)是微軟提供的一套面向Internet服務的API接口,一個ISAPI的DLL,可以在被用戶請求激活後長駐內存,等待用戶的另一個請求,還可以在一個DLL裡設置多個用戶請求處理函數,此外,ISAPI的DLL應用程序和WWW伺服器處於同一個進程中,效率要顯著高於CGI。 (由於微軟的排他性,只能運行於windows環境) 

   PHP作為Apache模組,Apache伺服器在系統啟動後,預先產生多個進程副本駐留在記憶體中,一旦有請求出現,就立即使用這些空餘的子進程進行處理,這樣就不存在生成子進程造成的延遲了。這些伺服器副本在處理完一次HTTP請求之後並不會立即退出,而是停留在電腦中等待下次要求。對於客戶瀏覽器的請求反應更快,效能較高。

相關推薦:

四種PHP運行模式詳解

#PHP運行模式總和

PHP運行模式的深入理解_PHP教程

以上是五大PHP運行模式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn