Windows 下 Nginx + PHP5 的安裝與配置

本文轉載至:www.phpvim.net/web/php/installing-nginx-with-php5-on-windows.html

Nginx 是一個輕量級的高性能 Http WebServer,以事件驅動方式編寫,因此相比 Apache 而言,Nginx 更加穩定、性能更好,而且配置簡單,資源佔用較低。以下是我在 Windows 7 安裝中 Nginx 和 PHP5.3 的步驟。

安裝 PHP5

首先,從 http://www.php.net/downloads.php 下載最新的 PHP 5.3 Windows 版本,解壓至 C:\php5,把壓縮包中的 php.ini-recommended,更名爲 php.ini,然後打開修改幾個選項:

error_reporting = E_ALL
display_errors = On
extension_dir = "C:\php5\ext"   ; 動態擴展,可以根據需要去掉 extension 前面的註釋 ; 
; 如加載 PDO, MySQL
extension=php_pdo.dll
extension=php_pdo_mysql.dll   ; CGI 設置
cgi.fix_pathinfo = 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

如果需要老版本的 Nginx for Windows,可以在 Kevin Worthington 的網站上面找找。

我使用的是 0.8.29,下載好以後,解壓釋放文件到 C:\nginx。

那麼如何配置 Nginx,使其可以和 PHP 協同工作?

配置 PHP FastCGI

Nginx 需要和 FastCGI Server 配合才能處理請求,有兩種方式運行 PHP FastCGI Server,一種就是使用 PHP 內置的 FastCGI 管理器:

1
C:/php5/php-cgi.exe -b 127.0.0.1:9000 -c C:/php5/php.ini

另外一種方式是使用第三方工具,比如 PHP-FPM 、cgi-fcgi 等。顯然!要在 Windows 中使用這些工具是件極其痛苦的事情,你可能需要 Cygwin 之類的東西才行,的確有人這麼做了,雖然我覺得那是自尋煩惱。

下一步,修改 Nginx ,將 php 請求轉發至 PHP FastCGI Server:

# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
location ~ ^(.+\.php)(.*)$ {
    root            D:/public_html;
    fastcgi_param   SCRIPT_FILENAME     $document_root$fastcgi_script_name;  
    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 配置文件:

# 連接到本機 9000 端口,這裏的端口是指 PHP FastCGI Server 開啓的端口,
# 請與 php-cgi.exe 開啓的端口保持一致
# 當 Nginx 收到 php 文件的請求時,會自動轉發到 PHP FastCGI Server
fastcgi_pass    127.0.0.1:9000;
fastcgi_index   index.php;   # Nginx 默認是不支持 CGI PATH_INFO,SCRIPT_NAME 的值也不標準(糅合了 PATH_INFO)
# 下面的兩行指令,可以從 SCRIPT_NAME 中剝離出 PATH_INFO
fastcgi_split_path_info     ^(.+\.php)(.*)$;
fastcgi_param PATH_INFO     $fastcgi_path_info;   include   fastcgi_params;

創建一個獨立的 php.conf 保存配置,純粹是爲了精簡 nginx.conf,個人習慣而已,也可以全部寫在主配置文件中。

修改 php.ini,設置 cgi.fix_pathinfo = 1,這非常重要,PHP 會修正 SCRIPT_FILENAME 爲真實的文件地址,否則 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 {… } 中加入如下命令:

1
2
3
autoindex on;
autoindex_exact_size on;
autoindex_localtime on;
OK,整合到一起

創建 start_nginx.bat,用於同時啓動 PHP FastCGI 和 Nginx:

@echo off
REM Windows 下無效
REM set PHP_FCGI_CHILDREN=5

REM 每個進程處理的最大請求數,或設置爲 Windows 環境變量
set PHP_FCGI_MAX_REQUESTS=1000   echo Starting PHP FastCGI...
RunHiddenConsole C:/php5/php-cgi.exe -b 127.0.0.1:9000 -c C:/php5/php.ini   echo Starting nginx...
C:/nginx/nginx.exe

RunHiddenConsole.exe 是一個用來隱藏 DOS 窗口的小程序,可以在這裏下載。 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

到這裏基本配置完畢了。

--------------------------------------------------------------------------

//華麗分割線

--------------------------------------------------------------------------

host文件中配置meteoric.com域名,指向本機。

照上面的文章所說,我本機配置如下:

#VHOST: meteoric.com     server {         listen 80;         server_name meteoric.com

        charset utf-8;         access_log off;

       ssi on;        ssi_silent_errors on;

       location / {             root C:\phpApp;                        index index.html index.php;         }

        location ~ ^(.+\.php)(.*)$ {             root C:\phpApp;             fastcgi_param    SCRIPT_FILENAME $document_root$fastcgi_script_name;              include php.conf;     }

}

fastcgi_params文件內容爲(fastcgi_params文件與nginx.conf位於同一目錄下):

fastcgi_param  QUERY_STRING       $query_string; fastcgi_param  REQUEST_METHOD     $request_method; fastcgi_param  CONTENT_TYPE       $content_type; fastcgi_param  CONTENT_LENGTH     $content_length;

fastcgi_param  SCRIPT_NAME        $fastcgi_script_name; fastcgi_param  REQUEST_URI        $request_uri; fastcgi_param  DOCUMENT_URI       $document_uri; fastcgi_param  DOCUMENT_ROOT      $document_root; fastcgi_param  SERVER_PROTOCOL    $server_protocol;

fastcgi_param  GATEWAY_INTERFACE  CGI/1.1; fastcgi_param  SERVER_SOFTWARE    nginx/$nginx_version;

fastcgi_param  REMOTE_ADDR        $remote_addr; fastcgi_param  REMOTE_PORT        $remote_port; fastcgi_param  SERVER_ADDR        $server_addr; fastcgi_param  SERVER_PORT        $server_port; fastcgi_param  SERVER_NAME        $server_name;

# PHP only, required if PHP was built with --enable-force-cgi-redirect fastcgi_param  REDIRECT_STATUS    200;

php.conf的配置:

# 連接到本機 9000 端口,這裏的端口是指 PHP FastCGI Server 開啓的端口, # 請與 php-cgi.exe 開啓的端口保持一致 # 當 Nginx 收到 php 文件的請求時,會自動轉發到 PHP FastCGI Server fastcgi_pass    127.0.0.1:9000; fastcgi_index   index.php;   # Nginx 默認是不支持 CGI PATH_INFO,SCRIPT_NAME 的值也不標準(糅合了 PATH_INFO) # 下面的兩行指令,可以從 SCRIPT_NAME 中剝離出 PATH_INFO fastcgi_split_path_info     ^(.+\.php)(.*)$; fastcgi_param PATH_INFO     $fastcgi_path_info;   include   fastcgi_params;

然後就是啓動php-cgi.exe了,在php安裝目錄下寫了個bat

php-cgi.exe -b 127.0.0.1:9000 -c php.ini

雙擊  talnet 127.0.0.1 9000  通了,然後測試…  配置meteoric.com指定本地127.0.0.1  運行測試、一切正常。OK

------------------------------------------------------------

------------------------------------------------------------

測試:

測試成功,下面就可以開始windows下的php開發之旅了~

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章