Windows下Nginx+PHP5的安裝與配置方法

來源:互聯網
上載者:User

以下是我在 Windows 2003 安裝中 Nginx 和 PHP5.2 的步驟,但 windows版本的nginx效能要比Linux/Uninx版本的Nginx差太多

安裝 PHP5
首先,從 http://www.php.net/downloads.php 下 載最新的 PHP5.2.9-2 Windows 版本,解壓至 C:\php,把壓縮包中的 php.ini-recommended,更名為 php.ini,然後開啟修改幾個選項:

error_reporting = E_ALL
display_errors = On
extension_dir = "C:\php\ext"

; 動態擴充,可以根據需要去掉 extension 前面的注釋 ;
; 如載入 PDO, MySQL
extension=php_pdo.dll
extension=php_pdo_mysql.dll

; CGI 設定
cgi.force_redirect = 1
cgi.fix_pathinfo = 1
cgi.rfc2616_headers = 1

PHP 載入擴充需要注意依賴性,比如 php_exif.dll 需要 php_mbstring.dll,你必須要把 php_mbstring.dll 放在 php_exif.dll 前面才能載入成功。有些擴充依賴額外的 dll 檔案,如 PHP 5.0+ ,php_mysqli.dll 依賴 libmysql.dll,而 php_oci8.dll,你則需要安裝 Oracle 8 的用戶端。如果你對這些依賴性不是太瞭解,可以參考一下安裝包中的 install.txt 檔案。

依賴檔案的搜尋順序:首先是 php.exe 所在的目錄,如果是 ISAPI 模式,那麼會搜尋 Web Server 的啟動位置,比如 Apache 的 bin 目錄;其次是 Windows PATH 環境變數中的目錄。這裡不要複 制任何檔案到 Windows 目錄中,有必要的話,可以把 C:\php5 加到 PATH 中,有利於以後 PHP 的升級。

安裝 Nginx
從 v0.7.52 開始,Nginx 開始發布 Windows 版本的 Nginx,你可以在其官方網站上面下載:http://nginx.net
我使用的是 0.8.37,下載好以後,解壓釋放檔案到 D:\nginx。

配置 PHP FastCGI
Nginx 需要和 FastCGI Server 配合才能處理請求,有兩種方式運行 PHP FastCGI Server,一種就是使用 PHP 內建的 FastCGI 管理器:
命令列下面執行c:/php/php-cgi.exe -b 127.0.0.1:9000 -c c:/php/php.ini以啟動PHP FastCGI

修改 Nginx 的設定檔 d\nginx\conf\nginx.conf,找到 php 相關的部分,修改如下:
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
location ~ \.php$ {
root d:/public_html;
include php.conf;
}
root 也就是 $document_root 指的是你的 php scripts 根目錄,設定為你的網站根目錄。在 Windows 下,需要注意的是 root 的路徑,最好使用 "/" 作為路徑分隔字元,而不是 Windows 預設的 "\",否則容易出問題,比如,這個路徑:d:\public_html\test,就不會起作用,Nginx 會拋出 500 錯誤,原因是 \test 中 \t 被解析為定位字元。當然再加上一個反斜線轉義也是可以的,如:d:\\public_html\\test。

php.conf 是我自己建立的用來儲存 php 配置的檔案,其實裡面只有 3 行命令:
# 串連到本機 9000 連接埠,這裡的連接埠是指 PHP FastCGI Server 開啟的連接埠,
# 請與 php-cgi.exe 開啟的連接埠保持一致
# 當 Nginx 收到 php 檔案的請求時,會自動轉寄到 PHP FastCGI Server
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi_params;
之所以要建立一個獨立的 php.conf 儲存配置為了精簡 nginx.conf,當在 nginx 中配置多個虛擬機器主機時,每個虛擬機器主機都需要配置 php,那麼主設定檔就會變得重複、臃腫。

需要修改一下 d:\nginx\conf\fastcgi_params 檔案,加入一行:
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

並且修改 php.ini,設定 cgi.fix_pathinfo = 1,這非常重要,否則 PHP 將無法找到需要處理的 php 指令碼。

一些其他的設定,主伺服器:
# 預設開啟的進程數
worker_processes 1;
error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
# 一個進程所處理的最大串連數上限,
# 本地開發,不需要預設的 1024,這裡改為 64
worker_connections 64;
}

當某個目錄下面不存在預設 index.php index.html 等首頁檔案時,Nginx 會拋出 403 ERROR,如果你需要羅列此目錄,則可以在 http {… } 中加入如下命令:
autoindex on;
autoindex_exact_size on;
autoindex_localtime on;

start_nginx.bat,用於同時啟動 PHP FastCGI 和 Nginx:
@echo off
echo Starting PHP FastCGI...
RunHiddenConsole c:/php/php-cgi.exe -b 127.0.0.1:9000 -c c:/php/php.ini
echo Starting nginx...
d:/nginx/nginx.exe
RunHiddenConsole.exe 是一個用來隱藏 DOS 視窗的小程式,可以在這裡下載RunHiddenConsole.zip (1.01 kb)。
start_nginx.bat 開啟後,也會有 DOS 視窗,但是可以安全的關掉,並不會關閉 Nginx 和 php-cgi.exe。
stop_nginx.bat,用來關閉:
@echo off
echo Stopping nginx...
taskkill /F /IM nginx.exe > nul
echo Stopping PHP FastCGI...
taskkill /F /IM php-cgi.exe > nul
exit
到這裡基本配置完畢了。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.