我一直以來都是以ISAPI 模式運行PHP 的,這種方式最大的缺點就是穩定性不好,當PHP 出錯的時候,Apache進程也死掉了。後來看到網路上關於PHP 以FastCGI 模式運作的介紹,其中提到的種種好處(穩定、安全、高效能)讓我決定嘗試一下。
不過事情遠不如預計的那麼順利。 Google 了無數次也沒找到一篇如何在Windows 下用Apache + FastCGI 跑PHP 的資料,IIS + FastCGI 跑PHP 的倒是不少。其中有一篇提到Zend 公司也推薦以FastCGI 模式運行PHP( http://phplens.com/phpeverywhere/fastcgi-php )。
經過幾個小時的摸索,終於成功實現了Apache 1.3 + FastCGI 跑PHP。
準備工作:
首先造訪http://www.fastcgi.com/dist/下載Apache 的mod_fastcgi。我使用的是mod_fastcgi-2.4.2-AP13.dll。下載後將這個檔案複製到Apache 的modules 目錄中。
下載PHP(我使用的PHP-5.0.4),並解壓縮,根據需要修改php.ini 檔案。注意不需要從PHP 所在目錄複製任何檔案到Windows 目錄中。
修改配置:
然後修改httpd.conf 文件,加入下面幾行:
LoadModule fastcgi_module modules/mod_fastcgi-2.4.2-AP13.dll
ScriptAlias /fcgi-php5/ "d:/usr/local/php-5.0.4/"
FastCgiServer "d:/usr/local/php-5.0.4/php-cgi.exe" -processes 3
# 說明:此處的-processes 3 表示啟動三個php-cgi.exe 進程,
# 關於FastCgiServer 的詳細參數請參考FastCGI 文件。
AddType application/x-httpd-fastphp5 .php
Action application/x-httpd-fastphp5 "/fcgi-php5/php-cgi.exe"
# 說明:根據你的PHP 檔案所在位置修改上面兩處黑體字。
修改完成後,重新啟動Apache 即可。
常見問題:
根據我的多次試驗,最容易出現的幾個問題主要都是由路徑引起的。因此首先檢查php.ini 和httpd.conf 檔案中的所有路徑是否正確。其次就是如果系統中先前安裝過PHP,那麼要將C:Windowsphp.ini 改名或刪除。
其次也要檢查PHP 檔案所在目錄是否有足夠的權限(我都是設定為Everyone - 完全控制,反正開髮用機不用考慮那麼多安全限制)。
FastCGI 模式運作PHP 的優點:
以FastCGI 模式運行PHP 有幾個主要的好處。首先就是PHP 出錯的時候不會搞垮Apache,只是PHP 自己的進程當掉(但FastCGI 會立即重新啟動一個新PHP 進程來取代當掉的進程)。其次FastCGI 模式運行PHP 比ISAPI 模式性能更好(我本來用ApacheBench 進行了測試,但忘了保存結果,大家有興趣可以自己測試)。
最後,就是可以同時運行PHP5 和PHP4。參考下面的設定文件,分別建立了兩個虛擬主機,其中一個使用PHP5,另一個使用PHP4。
LoadModule fastcgi_module modules/mod_fastcgi-2.4.2-AP13.dll
ScriptAlias /fcgi-php5/ "d:/usr/local/php-5.0.4/"
FastCgiServer "d:/usr/local/php-5.0.4/php-cgi.exe" -processes 3
ScriptAlias /fcgi-php4/ "d:/usr/local/php-4.3.11/"
FastCgiServer "d:/usr/local/php-4.3.11/php.exe"
Listen 80
NameVirtualHost *:80
DocumentRoot d:/www
Options Indexes FollowSymlinks MultiViews
ServerName php5.localhost
AddType application/x-httpd-fastphp5 .php
Action application/x-httpd-fastphp5 "/fcgi-php5/php-cgi.exe"
IndexOptions FancyIndexing FoldersFirst
Options Indexes FollowSymLinks MultiViews
AllowOverride None
Order allow,deny
Allow from all
Listen 8080
NameVirtualHost *:8080
DocumentRoot d:/www
Options Indexes FollowSymlinks MultiViews
ServerName php4.localhost
AddType application/x-httpd-fastphp4 .php
Action application/x-httpd-fastphp4 "/fcgi-php4/php.exe"
Options Indexes FollowSymLinks MultiViews
AllowOverride None
Order allow,deny
Allow from all
使用上面的配置,造訪http://localhost/就使用PHP5,而造訪http://localhost:8080/就使用PHP4。所以只要合理配置,就可以讓不同的虛擬主機使用不同版本的PHP。
FastCGI 模式的一些缺點:
說完了好處,也來說說缺點。從我的實際使用來看,用FastCGI 模式比較適合生產環境的伺服器。但對於開發用機器來說就不太適合。因為當使用Zend Studio 偵錯程式時,由於FastCGI 會認為PHP 進程逾時,因此在頁面傳回500 錯誤。這點讓人非常惱火,所以我在開發機器上還是換回了ISAPI 模式。
最後,在Windows 中以FastCGI 模式存在潛在的安全漏洞。因為我還沒有找到如何在Windows 環境下實現SuEXEC 的方法,因此PHP 的進程總是以最高權限運行,這從安全角度來看顯然不是個好消息。
結束語:
本文對FastCGI 的運用仍停留在很初級的階段,僅當作拋磚引玉,希望有更成熟的解決方案出現。