摘要:接下來會對其中五個比較常見的運行模式進行說明。模式是目前主流的服務運行模式,擁有高效可靠的性能,推薦大家使用。由于微軟的排他性,只能運行于環境。
SAPI
這里所說的 PHP 運行模式, 其實指的是 SAPI (Server Application Programming Interface,服務端應用編程端口 )。SAPI 為 PHP 提供了一個和外部通信的接口, PHP 就是通過這個接口來與其它的應用進行數據交互的。針對不同的應用場景, PHP 也提供了多種不同的 SAPI ,常見的有:apache、apache2filter、apache2handler、cli、cgi、embed 、fast-cgi、isapi 等等。
php_sapi_name() — 返回 web 服務器和 PHP 之間的接口類型。可能返回的值包括了 aolserver、apache、 apache2filter、apache2handler、 caudium、cgi (直到 PHP 5.3), cgi-fcgi、cli、 cli-server、 continuity、embed、fpm-fcgi、 isapi、litespeed、 milter、nsapi、 phttpd、pi3web、roxen、 thttpd、tux 和 webjames。
目前 PHP 內置的很多 SAPI 實現都已不再維護或者變的有些非主流了,PHP 社區目前正在考慮將一些 SAPI 移出代碼庫。 社區對很多功能的考慮是除非真的非常必要,或者某些功能已近非常通用了,否則就在 PECL 庫中。
接下來會對其中五個比較常見的運行模式進行說明。
CLI 模式CLI( Command Line Interface ), 也就是命令行接口,PHP 默認會安裝。通過這個接口,可以在 shell 環境下與 PHP 進行交互 。在終端里輸入 php -v,會得到類似下圖的結果(安裝了 PHP 前提下):
因為有 CLI 的存在,我們可以直接在終端命令行里運行 PHP 腳本,就像使用 shell、Python 那樣,不用依賴于 WEB 服務器。比如 Laravel 框架中的 Artisan 命令行工具,它其實就是一個 PHP 腳本,用來幫助我們快速構建 Laravel 應用的。
CGI 模式CGI(Common Gateway Interface,通用網關接口)是一種重要的互聯網技術,可以讓一個客戶端,從網頁瀏覽器向執行在網絡服務器上的程序請求數據。CGI 描述了服務器和請求處理程序之間傳輸數據的一種標準。
WEB 服務器只是內容的分發者。比如 Nginx,如果客戶端請求了 /index.html,那么 Nginx 會去文件系統中找到這個文件,發送給瀏覽器,這里分發的是靜態數據;如果客戶端現在請求的是 /index.php,根據配置文件,Nginx 知道這個不是靜態文件,需要去找 PHP 解析器來處理,那么它會把這個請求經過簡單處理后交給PHP 解析器。Nginx 會傳哪些數據給 PHP 解析器呢?url 要有吧,查詢字符串也得有吧,POST 數據也要有,HTTP 請求頭 不能少吧,好的,CGI 就是規定要傳哪些數據、以什么樣的格式傳遞給后方處理這個請求的協議。
CGI 模式運行原理:當 Nginx 收到瀏覽器 /index.php 這個請求后,首先會創建一個對應實現了 CGI 協議的進程,這里就是 php-cgi(PHP 解析器)。接下來 php-cgi 會解析 php.ini 文件,初始化執行環境,然后處理請求,再以 CGI 規定的格式返回處理后的結果,退出進程。最后,Nginx 再把結果返回給瀏覽器。整個流程就是一個 Fork-And-Execute 模式。當用戶請求數量非常多時,會大量擠占系統的資源如內存、CPU 時間等,造成效能低下。所以在用 CGI 方式的服務器下,有多少個連接請求就會有多少個 CGI 子進程,子進程反復加載是 CGI 性能低下的主要原因。
CGI 模式的好處就是完全獨立于任何服務器,僅僅是做為一個中介:提供接口給 WEB 服務器和腳本語言或者是完全獨立編程語言。它們通過 CGI 協議搭線來完成數據傳遞。這樣做的好處了盡量減少它們之間的關聯,使得各自更加獨立、互不影響。
CGI 模式已經是比較古老的模式了,這幾年都很少用了。
FastCGI 模式FastCGI(Fast Common Gateway Interface,快速通用網關接口)是一種讓交互程序與 Web 服務器通信的協議。FastCGI 是早期通用網關接口(CGI)的增強版本。FastCGI 致力于減少網頁服務器與 CGI 程序之間交互的開銷,從而使服務器可以同時處理更多的網頁請求。
根據定義可以知道,FastCGI 也是一種協議,實現了 FastCGI 協議的程序,更像是一個常駐型(long-live)的 CGI 協議程序,只要激活后,它可以一直執行著,不會每次都要花費時間去 fork 一次。
FastCGI 模式運行原理:FastCGI 進程管理器啟動之后,首先會解析 php.ini 文件,初始化執行環境,然后會啟動多個 CGI 協議解釋器守護進程 (進程管理中可以看到多個 php-cig 或 php-cgi.exe),并等待來自 WEB 服務器的連接;當客戶端請求到達 WEB 服務器時,FastCGI 進程管理器會選擇并連接到一個 CGI 解釋器, WEB 服務器將 CGI環境變量和標準輸入發送到 FastCGI 的子進程 php-cgi 中; php-cgi 子進程完成處理后便將標準輸出和錯誤信息返回給 WEB 服務器;此時 php-cgi 子進程就會關閉連接,該請求便處理結束,接著繼續等待并處理來自 FastCGI 進程管理器的下一個請求連接。
FastCGI 模式采用了 C/S 結構,可以將 WEB 服務器和腳本解析服務器分開,同時在腳本解析服務器上啟動一個或者多個腳本解析守護進程。當 WEB 服務器每次遇到動態程序時,可以將其直接交付給 FastCGI 進程來執行,然后將得到的結果返回給瀏覽器。這種方式可以讓 WEB 服務器專一地處理靜態請求或者將動態腳本服務器的結果返回給客戶端,這在很大程度上提高了整個應用系統的性能。
另外,在 CGI 模式下,php-cgi 在 php.ini 配置變更后,需要重啟 php-cgi 進程才能讓新的 php-ini 配置生效,不可以平滑重啟。而在 FastCGI 模式下,PHP-FPM 可以通過生成新的子進程來實現 php.ini 修改后的平滑重啟。
PHP-FPM(PHP-FastCGI Process Manager)是 PHP 語言中實現了 FastCGI 協議的進程管理器,由 Andrei Nigmatulin 編寫實現,已被 PHP 官方收錄并集成到內核中。
FastCGI 模式的優點:
從穩定性上看,FastCGI 模式是以獨立的進程池來運行 CGI 協議程序,多帶帶一個進程死掉,系統可以很輕易的丟棄,然后重新分配新的進程來運行邏輯;
從安全性上看,FastCGI 模式支持分布式運算。FastCGI 程序和宿主的 Server 完全獨立,FastCGI 程序掛了也不影響 Server;
從性能上看,FastCGI 模式把動態邏輯的處理從 Server 中分離出來,大負荷的 IO 處理還是留給宿主 Server,這樣宿主 Server 可以一心一意處理 IO,對于一個普通的動態網頁來說, 邏輯處理可能只有一小部分,大量的是圖片等靜態。
FastCGI 模式是目前 PHP 主流的 WEB 服務運行模式,擁有高效可靠的性能,推薦大家使用。
Module 模式PHP 常常與 Apache 服務器搭配形成 LAMP 配套的運行環境。把 PHP 作為一個子模塊集成到 Apache 中,就是 Module 模式,Apache 中的常見配置如下:
LoadModule php5_module modules/mod_php5.so
這使用了 LoadModule 命令,該命令的第一個參數是模塊的名稱,名稱可以在模塊實現的源碼中找到。第二個選項是該模塊所處的路徑。如果需要在服務器運行時加載模塊,可以通過發送信號 HUP 或者 AP_SIG_GRACEFUL 給服務器,一旦接受到該信號,Apache 將重新裝載模塊,而不需要重新啟動服務器。通過注冊到 apache2 的 ap_hook_post_config 掛鉤,在 Apache 啟動的時候啟動此模塊以接受 PHP 文件的請求。
例如,當客戶端訪問 PHP 文件時,Apache 就會調用 php5_module 來解析 PHP 腳本。Apache 每接收到一個請求,都會產生一個進程來連接 PHP 完成請求。在 Module 模式下,有時候會因為把 PHP 作為模塊編進 Apache,而導致出現問題時很難定位是 PHP 的問題還是 Apache 的問題。
過去,憑借著豐富的模塊和功能,企業往往將 Apache 作為 WEB 服務器,于是以 Module 模式運行的 PHP + Apache 的組合很常見。近些年,以異步事件驅動、高性能的 Nginx 服務器的崛起,市場份額快速增長,以 FastCGI 模式運行的 PHP + Nginx 組合,擁有更佳的性能,有趕超 Apache 的趨勢。ISAPI 模式
ISAPI(Internet Server Application Program Interface)是微軟提供的一套面向 Internet 服務的 API 接口,一個 ISAPI 的 DLL,可以在被用戶請求激活后長駐內存,等待用戶的另一個請求,還可以在一個 DLL 里設置多個用戶請求處理函數,此外,ISAPI 的 DLL 應用程序和 WEB 服務器處于同一個進程中,效率要顯著高于 CGI。由于微軟的排他性,只能運行于 Windows 環境。
用的比較少,在這里就不做詳細介紹了。
以上內容整理自網絡,參考文章:
SAPI概述
PHP的運行模式
PHP 運行模式
CGI、FastCGI和PHP-FPM關系圖解
搞不清FastCgi與PHP-fpm之間是個什么樣的關系
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/28659.html
摘要:當客戶端請求到達時,進程管理器選擇并連接到一個解釋器。子進程完成處理后將標準輸出和錯誤信息從同一連接返回。子進程接著等待并處理來自進程管理器運行在中的下一個連接。 目前常見的4種PHP運行模式 CGI通用網關接口模式 FAST-CGI模式 CLI命令行模式 模塊模式 運行模式 CGI通用網關接口模式 每有一個用戶請求,都會先要創建cgi的子進程,然后處理請求,處理完后結束這個子進程...
摘要:話說當下一共有種運行模式,分別是和模塊模式。使用,全稱進程管理器進行管理。工作原理啟動時載入進程管理器進程管理器自身初始化,啟動多個解釋器進程并等待來自的連接當客戶端請求到達時,進程管理器選擇并連接到一個解釋器。 我們知道 workerman 程序需要在php-cli模式下運行,也就是命令行模式,這塊我們有必要了解一下。 話說PHP當下一共有4種運行模式,分別是CGI、FastCGI、...
摘要:介紹每有一個用戶請求,都會先要創建的子進程,然后處理請求,處理完后結束這個子進程,這就是模式。當子進程關閉連接時,請求便告處理完成。子進程接著等待并處理來自進程管理器的下一個連接。運行在模式時,提供的方法。 本文介紹,PHP運行在FastCGI模式時,FPM提供的方法:fastcgi_finish_request。 在說這個方法之前,我們先了解PHP有哪些常用的運行模式? PHP運行模...
摘要:負責解釋執行文件生成響應,最終返回給,展現至前端。相比于傳統架構,進程模型最大的特點在于其多線程模式處理網絡請求,使得其能輕松應對大量連接。這要求開發人員對于多進程的運行模式有更清晰的認識更容易內存泄露。 一、SwooleSwoole號稱重新定義了PHP,它是一個PHP擴展,使得PHP可以使用異步的方式執行,就像node一樣,而且還能使用socket,為PHP提供了一系列異步IO、事件...
閱讀 3198·2023-04-26 01:30
閱讀 665·2021-11-08 13:15
閱讀 1774·2021-09-24 10:35
閱讀 998·2021-09-22 15:41
閱讀 1930·2019-08-30 15:44
閱讀 593·2019-08-30 13:22
閱讀 1004·2019-08-30 13:06
閱讀 1197·2019-08-29 13:22