転送: Windows での Nginx + PHP5 のインストールと構成
Nginx は、イベント駆動型の方法で記述された軽量で高性能な Http Web サーバーです。したがって、Nginx は、Apache と比較して、より安定しており、構成が簡単で、消費するリソースが少なくなります。 Windows 7 インストール上で Nginx と PHP5.2 に対して実行した手順は次のとおりです。
まず、最新の PHP5.2.9-2 Windows バージョンを http://www.php.net/downloads.php? からダウンロードし、C:php5 に解凍し、圧縮パッケージ内の php.ini-recommended の名前を変更します。 php.ini を開いて、いくつかのオプションを変更します:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
<span style="margin: 0px; color: #000099; padding: 0px;">error_reporting</span> <span style="margin: 0px; color: #000066; font-weight: bold; padding: 0px;">=</span><span style="margin: 0px; color: #660066; padding: 0px;"> E_ALL</span> <span style="margin: 0px; color: #000099; padding: 0px;">display_errors</span> <span style="margin: 0px; color: #000066; font-weight: bold; padding: 0px;">=</span><span style="margin: 0px; color: #660066; padding: 0px;"> On</span> <span style="margin: 0px; color: #000099; padding: 0px;">extension_dir</span> <span style="margin: 0px; color: #000066; font-weight: bold; padding: 0px;">=</span> <span style="margin: 0px; color: #993333; padding: 0px;">"C:\php5\ext"</span> ? <span style="font-style: italic; margin: 0px; color: #666666; padding: 0px;">; 动态扩展,可以根据需要去掉 extension 前面的注释 ; </span> <span style="font-style: italic; margin: 0px; color: #666666; padding: 0px;">; 如加载 PDO, MySQL</span> <span style="margin: 0px; color: #000099; padding: 0px;">extension</span><span style="margin: 0px; color: #000066; font-weight: bold; padding: 0px;">=</span><span style="margin: 0px; color: #660066; padding: 0px;">php_pdo.dll</span> <span style="margin: 0px; color: #000099; padding: 0px;">extension</span><span style="margin: 0px; color: #000066; font-weight: bold; padding: 0px;">=</span><span style="margin: 0px; color: #660066; padding: 0px;">php_pdo_mysql.dll</span> ? <span style="font-style: italic; margin: 0px; color: #666666; padding: 0px;">; CGI 设置</span> cgi.force_redirect <span style="margin: 0px; color: #000066; font-weight: bold; padding: 0px;">=</span><span style="margin: 0px; color: #660066; padding: 0px;"> 1</span> cgi.fix_pathinfo <span style="margin: 0px; color: #000066; font-weight: bold; padding: 0px;">=</span><span style="margin: 0px; color: #660066; padding: 0px;"> 1</span> cgi.rfc2616_headers <span style="margin: 0px; color: #000066; font-weight: bold; padding: 0px;">=</span><span style="margin: 0px; color: #660066; padding: 0px;"> 1</span> |
?
PHP の拡張機能をロードする場合は、依存関係に注意する必要があります。たとえば、php_exif.dll を正常にロードするには、php_mbstring.dll を php_exif.dll の前に置く必要があります。一部の拡張機能は、PHP 5.0 以降などの追加の dll ファイルに依存し、php_mysqli.dll は libmysql.dll に依存し、php_oci8.dll の場合は、Oracle 8 クライアントをインストールする必要があります。これらの依存関係についてよくわからない場合は、インストール パッケージの install.txt ファイルを参照してください。
依存ファイルの検索順序: 最初は php.exe が配置されているディレクトリ、次に Apache の bin ディレクトリなどの Web サーバーの起動場所が検索されます。 Windows PATH 環境変数内のディレクトリ。ここでは、 ファイルを Windows ディレクトリにコピーしません 必要に応じて、将来の PHP アップグレードを容易にするために C:php5 を PATH に追加できます。
v0.7.52 から、Nginx は Windows バージョンの Nginx をリリースし始めます。公式 Web サイト
http://nginx.net
Windows 用の Nginx の古いバージョンが必要な場合は、Kevin Worthington の Web サイトで見つけることができます。
私は 0.7.55 を使用しています。ダウンロード後、リリース ファイルを C:nginx に解凍します。
それでは、PHP で動作できるように Nginx を設定するにはどうすればよいでしょうか?
Nginx はリクエストを処理するために FastCGI サーバーと連携する必要があります。PHP FastCGI サーバーを実行するには 2 つの方法があります。1 つは PHP の組み込み FastCGI マネージャーを使用する方法です。
另外一种方式是使用第三方工具,比如 PHP-FPM 、cgi-fcgi 等。显然!要在 Windows 中使用这些工具是件极其痛苦的事情,你可能需要 Cygwin 之类的东西才行,的确有人这么做了,虽然我觉得那是自寻烦恼。
下一步,开始修改 Nginx 的配置文件 C:\nginx\conf\nginx.conf,找到 php 相关的部分,修改如下:
1 2 3 4 5 |
<span style="font-style: italic; margin: 0px; color: #adadad; padding: 0px;"># pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000</span> <span style="margin: 0px; color: #00007f; padding: 0px;">location</span> ~ \.php$ { root d:/public_html; <span style="margin: 0px; color: #00007f; padding: 0px;">include</span> 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 行命令:
1 2 3 4 5 6 |
<span style="font-style: italic; margin: 0px; color: #adadad; padding: 0px;"># 连接到本机 9000 端口,这里的端口是指 PHP FastCGI Server 开启的端口,</span> <span style="font-style: italic; margin: 0px; color: #adadad; padding: 0px;"># 请与 php-cgi.exe 开启的端口保持一致</span> <span style="font-style: italic; margin: 0px; color: #adadad; padding: 0px;"># 当 Nginx 收到 php 文件的请求时,会自动转发到 PHP FastCGI Server</span> fastcgi_pass 127.0.0.1:<span style="margin: 0px; color: #ff0000; padding: 0px;">9000</span>; fastcgi_index index.php; <span style="margin: 0px; color: #00007f; padding: 0px;">include</span> fastcgi_params; |
之所以要创建一个独立的 php.conf 保存配置为了精简 nginx.conf,当在 nginx 中配置多个虚拟主机时,每个虚拟主机都需要配置 php,那么主配置文件就会变得重复、臃肿。
除此以外,还需要修改一下 c:\nginx\conf\fastcgi_params 文件,加入一行:
1 |
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; |
并且修改 php.ini,设置 cgi.fix_pathinfo = 1,这非常重要,否则 PHP 将无法找到需要处理的 php 脚本。
一些其他的设置,主服务器:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
<span style="font-style: italic; margin: 0px; color: #adadad; padding: 0px;"># 默认开启的进程数</span> worker_processes <span style="margin: 0px; color: #ff0000; padding: 0px;">1</span>; ? error_log logs/error.log; <span style="font-style: italic; margin: 0px; color: #adadad; padding: 0px;">#error_log logs/error.log notice;</span> <span style="font-style: italic; margin: 0px; color: #adadad; padding: 0px;">#error_log logs/error.log info;</span> ? <span style="font-style: italic; margin: 0px; color: #adadad; padding: 0px;">#pid logs/nginx.pid;</span> ? events { <span style="font-style: italic; margin: 0px; color: #adadad; padding: 0px;"># 一个进程所处理的最大连接数上限,</span> <span style="font-style: italic; margin: 0px; color: #adadad; padding: 0px;"># 本地开发,不需要默认的 1024,这里改为 64</span> worker_connections <span style="margin: 0px; color: #ff0000; padding: 0px;">64</span>; } |
当某个目录下面不存在默认 index.php index.html 等首页文件时,Nginx 会抛出 403 ERROR,如果你需要罗列此目录,则可以在 http {… } 中加入如下命令:
1 2 3 |
autoindex <span style="margin: 0px; color: #0000ff; padding: 0px;">on</span>; autoindex_exact_size <span style="margin: 0px; color: #0000ff; padding: 0px;">on</span>; autoindex_localtime <span style="margin: 0px; color: #0000ff; padding: 0px;">on</span>; |
创建 start_nginx.bat,用于同时启动 PHP FastCGI 和 Nginx:
1 2 3 4 5 6 |
<span style="margin: 0px; color: #33cc33; padding: 0px;">@</span><span style="margin: 0px; color: #b1b100; font-weight: bold; padding: 0px;">echo</span> off <span style="margin: 0px; color: #b1b100; font-weight: bold; padding: 0px;">echo</span> Starting PHP FastCGI... RunHiddenConsole c:/php5/php-cgi.exe -b 127.0.0.1:<span style="margin: 0px; color: #cc66cc; padding: 0px;">9000</span> -c c:/php5/php.ini ? <span style="margin: 0px; color: #b1b100; font-weight: bold; padding: 0px;">echo</span> Starting nginx... c:/nginx/nginx.exe |
RunHiddenConsole.exe 是一个用来隐藏 DOS 窗口的小程序,可以在这里下载。
start_nginx.bat 开启后,也会有 DOS 窗口,但是可以安全的关掉,并不会关闭 Nginx 和 php-cgi.exe。
同样 stop_nginx.bat,用来关闭:
1 2 3 4 5 6 |
<span style="margin: 0px; color: #33cc33; padding: 0px;">@</span><span style="margin: 0px; color: #b1b100; font-weight: bold; padding: 0px;">echo</span> off <span style="margin: 0px; color: #b1b100; font-weight: bold; padding: 0px;">echo</span> Stopping nginx... taskkill /F /IM nginx.exe > <span style="margin: 0px; color: #0000ff; font-weight: bold; padding: 0px;">nul</span> <span style="margin: 0px; color: #b1b100; font-weight: bold; padding: 0px;">echo</span> Stopping PHP FastCGI... taskkill /F /IM php-cgi.exe > <span style="margin: 0px; color: #0000ff; font-weight: bold; padding: 0px;">nul</span> <span style="margin: 0px; color: #00b100; font-weight: bold; padding: 0px;">exit</span> |
到这里基本配置完毕了。