国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > PHP > 正文

PHP的運行模式

2019-11-06 07:35:27
字體:
供稿:網(wǎng)友

1、運行模式

關(guān)于php目前比較常見的五大運行模式:

1)CGI(通用網(wǎng)關(guān)接口 / Common Gateway Interface)

2)FastCGI(常駐型CGI / Long-Live CGI)

3)CLI(命令行運行 / Command Line Interface)

4)Web模塊模式(Apache等Web服務(wù)器運行的模式)

5)ISAPI(Internet Server application PRogram Interface)

備注:在PHP5.3以后,PHP不再有ISAPI模式,安裝后也不再有php5isapi.dll這個文件。要在IIS6上使用高版本PHP,必須安裝FastCGI 擴展,然后使IIS6支持FastCGI。

1.1 CGI模式

  CGI即通用網(wǎng)關(guān)接口(Common Gateway Interface),它是一段程序,通俗的講CGI就象是一座橋,把網(wǎng)頁和Web服務(wù)器中的執(zhí)行程序連接起來,它把HTML接收的指令傳遞給服務(wù)器的執(zhí)行程序,再把服務(wù)器執(zhí)行程序的結(jié)果返還給HTML頁。CGI 的跨平臺性能極佳,幾乎可以在任何操作系統(tǒng)上實現(xiàn)。 CGI已經(jīng)是比較老的模式了,這幾年都很少用了。

  每有一個用戶請求,都會先要創(chuàng)建CGI的子進程,然后處理請求,處理完后結(jié)束這個子進程,這就是Fork-And-Execute模式。 當(dāng)用戶請求數(shù)量非常多時,會大量擠占系統(tǒng)的資源如內(nèi)存,CPU時間等,造成效能低下。所以用CGI方式的服務(wù)器有多少連接請求就會有多少CGI子進程,子進程反復(fù)加載是CGI性能低下的主要原因。

  如果不想把 PHP 嵌入到服務(wù)器端軟件(如 Apache)作為一個模塊安裝的話,可以選擇以 CGI 的模式安裝。或者把 PHP 用于不同的 CGI 封裝以便為代碼創(chuàng)建安全的 chroot 和 setuid 環(huán)境。這樣每個客戶機請求一個PHP文件,Web服務(wù)器就調(diào)用php.exe(win下是php.exe,linux是php)去解釋這個文件,然后再把解釋的結(jié)果以網(wǎng)頁的形式返回給客戶機。 這種安裝方式通常會把 PHP 的可執(zhí)行文件安裝到 web 服務(wù)器的 cgi-bin 目錄。CERT 建議書 CA-96.11 建議不要把任何的解釋器放到 cgi-bin 目錄。

  這種方式的好處是把Web Server和具體的程序處理獨立開來,結(jié)構(gòu)清晰,可控性強,同時缺點就是如果在高訪問需求的情況下,CGI的進程Fork就會成為很大的服務(wù)器負擔(dān),想 象一下數(shù)百個并發(fā)請求導(dǎo)致服務(wù)器Fork出數(shù)百個進程就明白了。這也是為什么CGI一直背負性能低下,高資源消耗的惡名的原因。

1.2 FastCGI模式

  FastCGI是CGI的升級版本,F(xiàn)astCGI像是一個常駐 (long-live)型的 CGI,它可以一直執(zhí)行著,只要激活后,不會每次都要花費時間去 Fork 一次 (這是 CGI 最為人詬病的 fork-and-execute 模式)。

  FastCGI是一個可伸縮地、高速地在HTTP server和動態(tài)腳本語言間通信的接口。多數(shù)流行的HTTP server都支持FastCGI,包括Apache、Nginx和lighttpd等,同時,F(xiàn)astCGI也被許多腳本語言所支持,其中就有PHP。

  FastCGI接口方式采用C/S結(jié)構(gòu),可以將HTTP服務(wù)器和腳本解析服務(wù)器分開,同時在腳本解析服務(wù)器上啟動一個或者多個腳本解析守護進程。當(dāng)HTTP服務(wù)器每次遇到動態(tài)程序時,可以將其直接交付給FastCGI進程來執(zhí)行,然后將得到的結(jié)果返回給瀏覽器。這種方式可以讓HTTP服務(wù)器專一地處理靜態(tài)請求或者將動態(tài)腳本服務(wù)器的結(jié)果返回給客戶端,這在很大程度上提高了整個應(yīng)用系統(tǒng)的性能。

【原理】

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

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

3)當(dāng)客戶端請求到達Web Server時,F(xiàn)astCGI進程管理器選擇并連接到一個CGI解釋器。Web server將CGI環(huán)境變量和標準輸入發(fā)送到FastCGI子進程php-cgi;

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

  在CGI模式中,你可以想象 CGI通常有多慢。每一個Web請求PHP都必須重新解析php.ini、重新載入全部dll擴展并重初始化全部數(shù)據(jù)結(jié)構(gòu)。使用FastCGI,所有這些都只在進程啟動時發(fā)生一次。一個額外的好處是,持續(xù)數(shù)據(jù)庫連接(Persistent database connection)可以工作。

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

【優(yōu)點】

1)從穩(wěn)定性上看,F(xiàn)astCGI是以獨立的進程池來運行CGI,單獨一個進程死掉,系統(tǒng)可以很輕易的丟棄,然后重新分配新的進程來運行邏輯;

2)從安全性上看,F(xiàn)astCGI支持分布式運算。FastCGI和宿主的Server完全獨立,F(xiàn)astCGI怎么down也不會把Server搞垮;

3)從性能上看,F(xiàn)astCGI把動態(tài)邏輯的處理從Server中分離出來,大負荷的IO處理還是留給宿主Server,這樣宿主Server可以一心一意作IO,對于一個普通的動態(tài)網(wǎng)頁來說, 邏輯處理可能只有一小部分,大量的是圖片等靜態(tài)。

【缺點】

  說完了好處,也來說說缺點。從我的實際使用來看,用FastCGI模式更適合生產(chǎn)環(huán)境的服務(wù)器。但對于開發(fā)用機器來說就不太合適。因為當(dāng)使用 Zend Studio調(diào)試程序時,由于 FastCGI會認為 PHP進程超時,從而在頁面返回 500錯誤。這一點讓人非常惱火,所以我在開發(fā)機器上還是換回了 ISAPI模式。對某些服務(wù)器的新版本支持不好,對分布式負載均衡沒要求的模塊化安裝是否是更好的選擇。目前的FastCGI和Server溝通還不夠智能,一個FastCGI進程如果執(zhí)行時間過長會被當(dāng)成是死進程殺掉重起,這樣在處理長時間任務(wù)的時候很麻煩,這樣做也使得FastCGI無法允許聯(lián)機調(diào)試。因為是多進程,所以比CGI多線程消耗更多的服務(wù)器內(nèi)存,PHP-CGI解釋器每進程消耗7至25兆內(nèi)存,將這個數(shù)字乘以50或100就是很大的內(nèi)存數(shù)。

1.3 CLI模式

  PHP-CLI是PHP Command Line Interface的簡稱,如同它名字的意思,就是PHP在命令行運行的接口,區(qū)別于在Web服務(wù)器上運行的PHP環(huán)境(PHP-CGI,ISAPI等)。 也就是說,PHP不單可以寫前臺網(wǎng)頁,它還可以用來寫后臺的程序。 PHP的CLI Shell腳本適用于所有的PHP優(yōu)勢,使創(chuàng)建要么支持腳本或系統(tǒng)甚至與GUI應(yīng)用程序的服務(wù)端,在Windows和Linux下都是支持PHP-CLI模式的。

【優(yōu)點】

1)使用多進程,子進程結(jié)束以后,內(nèi)核會負責(zé)回收資源;

2)使用多進程,子進程異常退出不會導(dǎo)致整個進程Thread退出,父進程還有機會重建流程;

3)一個常駐主進程,只負責(zé)任務(wù)分發(fā),邏輯更清楚。

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

1.4 模塊模式

  模塊模式是以mod_php5模塊的形式集成,此時mod_php5模塊的作用是接收Apache傳遞過來的PHP文件請求,并處理這些請求,然后將處理后的結(jié)果返回給Apache。如果我們在Apache啟動前在其配置文件中配置好了PHP模塊(mod_php5), PHP模塊通過注冊apache2的ap_hook_post_config掛鉤,在Apache啟動的時候啟動此模塊以接受PHP文件的請求。

  除了這種啟動時的加載方式,Apache的模塊可以在運行的時候動態(tài)裝載,這意味著對服務(wù)器可以進行功能擴展而不需要重新對源代碼進行編譯,甚至根本不需要停止服務(wù)器。我們所需要做的僅僅是給服務(wù)器發(fā)送信號HUP或者AP_SIG_GRACEFUL通知服務(wù)器重新載入模塊。但是在動態(tài)加載之前,我們需要將模塊編譯成為動態(tài)鏈接庫。此時的動態(tài)加載就是加載動態(tài)鏈接庫。 Apache中對動態(tài)鏈接庫的處理是通過模塊mod_so來完成的,因此mod_so模塊不能被動態(tài)加載,它只能被靜態(tài)編譯進Apache的核心。這意味著它是隨著Apache一起啟動的。

  Apache是如何加載模塊的呢?我們以前面提到的mod_php5模塊為例。首先我們需要在Apache的配置文件httpd.conf中添加一行:

LoadModule php5_module modules/mod_php5.so

  這里我們使用了LoadModule命令,該命令的第一個參數(shù)是模塊的名稱,名稱可以在模塊實現(xiàn)的源碼中找到。第二個選項是該模塊所處的路徑。如果需要在服務(wù)器運行時加載模塊,可以通過發(fā)送信號HUP或者AP_SIG_GRACEFUL給服務(wù)器,一旦接受到該信號,Apache將重新裝載模塊,而不需要重新啟動服務(wù)器。

  該運行模式是我們以前在windows環(huán)境下使用apache服務(wù)器經(jīng)常使用的,而在模塊化(DLL)中,PHP是與Web服務(wù)器一起啟動并運行的。(它是apache在CGI的基礎(chǔ)上進行的一種擴展,加快PHP的運行效率)。

1.5 ISAPI模式

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

  PHP作為Apache模塊,Apache服務(wù)器在系統(tǒng)啟動后,預(yù)先生成多個進程副本駐留在內(nèi)存中,一旦有請求出現(xiàn),就立即使用這些空余的子進程進行處理,這樣就不存在生成子進程造成的延遲了。這些服務(wù)器副本在處理完一次HTTP請求之后并不立即退出,而是停留在計算機中等待下次請求。對于客戶瀏覽器的請求反應(yīng)更快,性能較高。

2、參考文獻

1.PHP運行模式


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 中西区| 班玛县| 凤城市| 庆安县| 南通市| 和平区| 中宁县| 延津县| 佛学| 西华县| 盐池县| 大洼县| 河间市| 夏津县| 临湘市| 阿坝县| 安平县| 尖扎县| 孟州市| 神池县| 封开县| 新昌县| 乌海市| 甘孜县| 准格尔旗| 子洲县| 莒南县| 万源市| 郯城县| 桑植县| 京山县| 铜梁县| 宜宾县| 永年县| 玉田县| 申扎县| 方山县| 饶阳县| 拜泉县| 普格县| 南岸区|