Windows下Nginx + PHP5 的安裝與配置方法
更新時(shí)間:2010年07月02日 23:17:42 作者:
Nginx 是一個(gè)輕量級(jí)的高性能 Http WebServer,以事件驅(qū)動(dòng)方式編寫(xiě),因此相比 Apache 而言,Nginx 更加穩(wěn)定、性能更好,而且配置簡(jiǎn)單,資源占用較低。以下是我在 Windows 7 安裝中 Nginx 和 PHP5.3 的步驟。
安裝 PHP5
首先,從 http://www.php.net/downloads.php 下載最新的 PHP 5.3 Windows 版本,解壓至 C:\php5,把壓縮包中的 php.ini-recommended,更名為 php.ini,然后打開(kāi)修改幾個(gè)選項(xiàng):
error_reporting = E_ALL
display_errors = On
extension_dir = "C:\php5\ext"
; 動(dòng)態(tài)擴(kuò)展,可以根據(jù)需要去掉 extension 前面的注釋 ;
; 如加載 PDO, MySQL
extension=php_pdo.dll
extension=php_pdo_mysql.dll
; CGI 設(shè)置
cgi.fix_pathinfo = 1
PHP 加載擴(kuò)展需要注意依賴性,比如 php_exif.dll 需要 php_mbstring.dll,你必須要把 php_mbstring.dll 放在 php_exif.dll 前面才能加載成功。有些擴(kuò)展依賴額外的 dll 文件,如 PHP 5.0+ ,php_mysqli.dll 依賴 libmysql.dll,而 php_oci8.dll,你則需要安裝 Oracle 8 的客戶端。如果你對(duì)這些依賴性不是太了解,可以參考一下安裝包中的 install.txt 文件。
依賴文件的搜索順序:首先是 php.exe 所在的目錄,如果是 ISAPI 模式,那么會(huì)搜索 Web Server 的啟動(dòng)位置,比如 Apache 的 bin 目錄;其次是 Windows PATH 環(huán)境變量中的目錄。這里不要復(fù)制任何文件到 Windows 目錄中,有必要的話,可以把 C:\php5 加到 PATH 中,便于以后 PHP 的升級(jí)。
安裝 Nginx
從 v0.7.52 開(kāi)始,Nginx 開(kāi)始發(fā)布 Windows 版本的 Nginx,你可以在其官方網(wǎng)站上面下載:
http://nginx.net
如果需要老版本的 Nginx for Windows,可以在 Kevin Worthington 的網(wǎng)站上面找找。
我使用的是 0.8.29,下載好以后,解壓釋放文件到 C:\nginx。
那么如何配置 Nginx,使其可以和 PHP 協(xié)同工作?
配置 PHP FastCGI
Nginx 需要和 FastCGI Server 配合才能處理請(qǐng)求,有兩種方式運(yùn)行 PHP FastCGI Server,一種就是使用 PHP 內(nèi)置的 FastCGI 管理器:
C:/php5/php-cgi.exe -b 127.0.0.1:9000 -c C:/php5/php.ini
另外一種方式是使用第三方工具,比如 PHP-FPM 、cgi-fcgi 等。顯然!要在 Windows 中使用這些工具是件極其痛苦的事情,你可能需要 Cygwin 之類的東西才行,的確有人這么做了,雖然我覺(jué)得那是自尋煩惱。
下一步,修改 Nginx ,將 php 請(qǐng)求轉(zhuǎn)發(fā)至 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 根目錄,設(shè)置為你的網(wǎng)站根目錄。在 Windows 下,需要注意的是 root 的路徑,最好使用 "/" 作為路徑分隔符,而不是 Windows 默認(rèn)的 "\",否則容易出問(wèn)題,比如,這個(gè)路徑:D:\public_html\test,就不會(huì)起作用,Nginx 會(huì)拋出 500 錯(cuò)誤,原因是 \test 中 \t 被解析為制表符。當(dāng)然再加上一個(gè)反斜杠轉(zhuǎn)義也是可以的,如:D:\\public_html\\test。
php.conf 配置文件:
# 連接到本機(jī) 9000 端口,這里的端口是指 PHP FastCGI Server 開(kāi)啟的端口,
# 請(qǐng)與 php-cgi.exe 開(kāi)啟的端口保持一致
# 當(dāng) Nginx 收到 php 文件的請(qǐng)求時(shí),會(huì)自動(dòng)轉(zhuǎn)發(fā)到 PHP FastCGI Server
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
# Nginx 默認(rèn)是不支持 CGI PATH_INFO,SCRIPT_NAME 的值也不標(biāo)準(zhǔn)(糅合了 PATH_INFO)
# 下面的兩行指令,可以從 SCRIPT_NAME 中剝離出 PATH_INFO
fastcgi_split_path_info ^(.+\.php)(.*)$;
fastcgi_param PATH_INFO $fastcgi_path_info;
include fastcgi_params;
創(chuàng)建一個(gè)獨(dú)立的 php.conf 保存配置,純粹是為了精簡(jiǎn) nginx.conf,個(gè)人習(xí)慣而已,也可以全部寫(xiě)在主配置文件中。
修改 php.ini,設(shè)置 cgi.fix_pathinfo = 1,這非常重要,PHP 會(huì)修正 SCRIPT_FILENAME 為真實(shí)的文件地址,否則 PHP 將無(wú)法找到需要處理的 php 文件。
一些其他的設(shè)置,主服務(wù)器:
# 默認(rèn)開(kāi)啟的進(jìn)程數(shù)
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 {
# 一個(gè)進(jìn)程所處理的最大連接數(shù)上限,
# 本地開(kāi)發(fā),不需要默認(rèn)的 1024,這里改為 64
worker_connections 64;
}
當(dāng)某個(gè)目錄下面不存在默認(rèn) index.php index.html 等首頁(yè)文件時(shí),Nginx 會(huì)拋出 403 ERROR,如果你需要羅列此目錄,則可以在 http {… } 中加入如下命令:
autoindex on;
autoindex_exact_size on;
autoindex_localtime on;
OK,整合到一起
創(chuàng)建 start_nginx.bat,用于同時(shí)啟動(dòng) PHP FastCGI 和 Nginx:
@echo off
REM Windows 下無(wú)效
REM set PHP_FCGI_CHILDREN=5
REM 每個(gè)進(jìn)程處理的最大請(qǐng)求數(shù),或設(shè)置為 Windows 環(huán)境變量
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 是一個(gè)用來(lái)隱藏 DOS 窗口的小程序,可以在這里下載。
start_nginx.bat 開(kāi)啟后,也會(huì)有 DOS 窗口,但是可以安全的關(guān)掉,并不會(huì)關(guān)閉 Nginx 和 php-cgi.exe。
同樣 stop_nginx.bat,用來(lái)關(guān)閉:
@echo off
echo Stopping nginx...
taskkill /F /IM nginx.exe > nul
echo Stopping PHP FastCGI...
taskkill /F /IM php-cgi.exe > nul
exit
到這里基本配置完畢了。
首先,從 http://www.php.net/downloads.php 下載最新的 PHP 5.3 Windows 版本,解壓至 C:\php5,把壓縮包中的 php.ini-recommended,更名為 php.ini,然后打開(kāi)修改幾個(gè)選項(xiàng):
復(fù)制代碼 代碼如下:
error_reporting = E_ALL
display_errors = On
extension_dir = "C:\php5\ext"
; 動(dòng)態(tài)擴(kuò)展,可以根據(jù)需要去掉 extension 前面的注釋 ;
; 如加載 PDO, MySQL
extension=php_pdo.dll
extension=php_pdo_mysql.dll
; CGI 設(shè)置
cgi.fix_pathinfo = 1
PHP 加載擴(kuò)展需要注意依賴性,比如 php_exif.dll 需要 php_mbstring.dll,你必須要把 php_mbstring.dll 放在 php_exif.dll 前面才能加載成功。有些擴(kuò)展依賴額外的 dll 文件,如 PHP 5.0+ ,php_mysqli.dll 依賴 libmysql.dll,而 php_oci8.dll,你則需要安裝 Oracle 8 的客戶端。如果你對(duì)這些依賴性不是太了解,可以參考一下安裝包中的 install.txt 文件。
依賴文件的搜索順序:首先是 php.exe 所在的目錄,如果是 ISAPI 模式,那么會(huì)搜索 Web Server 的啟動(dòng)位置,比如 Apache 的 bin 目錄;其次是 Windows PATH 環(huán)境變量中的目錄。這里不要復(fù)制任何文件到 Windows 目錄中,有必要的話,可以把 C:\php5 加到 PATH 中,便于以后 PHP 的升級(jí)。
安裝 Nginx
從 v0.7.52 開(kāi)始,Nginx 開(kāi)始發(fā)布 Windows 版本的 Nginx,你可以在其官方網(wǎng)站上面下載:
http://nginx.net
如果需要老版本的 Nginx for Windows,可以在 Kevin Worthington 的網(wǎng)站上面找找。
我使用的是 0.8.29,下載好以后,解壓釋放文件到 C:\nginx。
那么如何配置 Nginx,使其可以和 PHP 協(xié)同工作?
配置 PHP FastCGI
Nginx 需要和 FastCGI Server 配合才能處理請(qǐng)求,有兩種方式運(yùn)行 PHP FastCGI Server,一種就是使用 PHP 內(nèi)置的 FastCGI 管理器:
C:/php5/php-cgi.exe -b 127.0.0.1:9000 -c C:/php5/php.ini
另外一種方式是使用第三方工具,比如 PHP-FPM 、cgi-fcgi 等。顯然!要在 Windows 中使用這些工具是件極其痛苦的事情,你可能需要 Cygwin 之類的東西才行,的確有人這么做了,雖然我覺(jué)得那是自尋煩惱。
下一步,修改 Nginx ,將 php 請(qǐng)求轉(zhuǎn)發(fā)至 PHP FastCGI Server:
復(fù)制代碼 代碼如下:
# 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 根目錄,設(shè)置為你的網(wǎng)站根目錄。在 Windows 下,需要注意的是 root 的路徑,最好使用 "/" 作為路徑分隔符,而不是 Windows 默認(rèn)的 "\",否則容易出問(wèn)題,比如,這個(gè)路徑:D:\public_html\test,就不會(huì)起作用,Nginx 會(huì)拋出 500 錯(cuò)誤,原因是 \test 中 \t 被解析為制表符。當(dāng)然再加上一個(gè)反斜杠轉(zhuǎn)義也是可以的,如:D:\\public_html\\test。
php.conf 配置文件:
復(fù)制代碼 代碼如下:
# 連接到本機(jī) 9000 端口,這里的端口是指 PHP FastCGI Server 開(kāi)啟的端口,
# 請(qǐng)與 php-cgi.exe 開(kāi)啟的端口保持一致
# 當(dāng) Nginx 收到 php 文件的請(qǐng)求時(shí),會(huì)自動(dòng)轉(zhuǎn)發(fā)到 PHP FastCGI Server
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
# Nginx 默認(rèn)是不支持 CGI PATH_INFO,SCRIPT_NAME 的值也不標(biāo)準(zhǔn)(糅合了 PATH_INFO)
# 下面的兩行指令,可以從 SCRIPT_NAME 中剝離出 PATH_INFO
fastcgi_split_path_info ^(.+\.php)(.*)$;
fastcgi_param PATH_INFO $fastcgi_path_info;
include fastcgi_params;
創(chuàng)建一個(gè)獨(dú)立的 php.conf 保存配置,純粹是為了精簡(jiǎn) nginx.conf,個(gè)人習(xí)慣而已,也可以全部寫(xiě)在主配置文件中。
修改 php.ini,設(shè)置 cgi.fix_pathinfo = 1,這非常重要,PHP 會(huì)修正 SCRIPT_FILENAME 為真實(shí)的文件地址,否則 PHP 將無(wú)法找到需要處理的 php 文件。
一些其他的設(shè)置,主服務(wù)器:
復(fù)制代碼 代碼如下:
# 默認(rèn)開(kāi)啟的進(jìn)程數(shù)
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 {
# 一個(gè)進(jìn)程所處理的最大連接數(shù)上限,
# 本地開(kāi)發(fā),不需要默認(rèn)的 1024,這里改為 64
worker_connections 64;
}
當(dāng)某個(gè)目錄下面不存在默認(rèn) index.php index.html 等首頁(yè)文件時(shí),Nginx 會(huì)拋出 403 ERROR,如果你需要羅列此目錄,則可以在 http {… } 中加入如下命令:
復(fù)制代碼 代碼如下:
autoindex on;
autoindex_exact_size on;
autoindex_localtime on;
OK,整合到一起
創(chuàng)建 start_nginx.bat,用于同時(shí)啟動(dòng) PHP FastCGI 和 Nginx:
復(fù)制代碼 代碼如下:
@echo off
REM Windows 下無(wú)效
REM set PHP_FCGI_CHILDREN=5
REM 每個(gè)進(jìn)程處理的最大請(qǐng)求數(shù),或設(shè)置為 Windows 環(huán)境變量
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 是一個(gè)用來(lái)隱藏 DOS 窗口的小程序,可以在這里下載。
start_nginx.bat 開(kāi)啟后,也會(huì)有 DOS 窗口,但是可以安全的關(guān)掉,并不會(huì)關(guān)閉 Nginx 和 php-cgi.exe。
同樣 stop_nginx.bat,用來(lái)關(guān)閉:
復(fù)制代碼 代碼如下:
@echo off
echo Stopping nginx...
taskkill /F /IM nginx.exe > nul
echo Stopping PHP FastCGI...
taskkill /F /IM php-cgi.exe > nul
exit
到這里基本配置完畢了。
相關(guān)文章
使用nginx+lua進(jìn)行token鑒權(quán)的方法
使用nginx和lua腳本實(shí)現(xiàn)對(duì)Minio服務(wù)器圖片鏈接的token鑒權(quán),通過(guò)反向代理隱藏真實(shí)IP,增強(qiáng)安全性,介紹了整個(gè)鑒權(quán)流程,包括nginx配置和lua腳本的具體實(shí)現(xiàn),適用于需要保護(hù)圖片不被未授權(quán)訪問(wèn)的場(chǎng)景2022-05-05nginx http模塊數(shù)據(jù)存儲(chǔ)結(jié)構(gòu)小結(jié)
這篇文章主要介紹了nginx http模塊數(shù)據(jù)存儲(chǔ)結(jié)構(gòu)小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02前端加載訪問(wèn)速度優(yōu)化詳細(xì)指南(Nginx)
在前端開(kāi)發(fā)中,優(yōu)化頁(yè)面加載速度成為了開(kāi)發(fā)者的一項(xiàng)重要任務(wù),下面這篇文章主要給大家介紹了關(guān)于前端加載訪問(wèn)速度優(yōu)化(Nginx)的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-06-06Nginx的安裝和多域名配置的實(shí)現(xiàn)方法
這篇文章主要介紹了Nginx的安裝和多域名配置的實(shí)現(xiàn)方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09詳解nginx請(qǐng)求頭數(shù)據(jù)讀取流程
這篇文章主要介紹了詳解nginx請(qǐng)求頭數(shù)據(jù)讀取流程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03nginx反向代理導(dǎo)致session失效的問(wèn)題解決
這篇文章主要介紹了nginx反向代理導(dǎo)致session失效的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06nginx環(huán)境下配置ssl加密(單雙向認(rèn)證、部分https)
這篇文章主要介紹了nginx環(huán)境下配置ssl加密(單雙向認(rèn)證、部分https),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-11-11