Windows下IIS以FastCGI模式運行PHP

因爲PHP5.3 的改進,原有的IIS 經過isapi 方式解析PHP腳本已經不被支持,PHP從5.3.0 之後的版本開始使用微軟的 fastcgi 模式,這是一個更先進的方式,運行速度更快,更穩定。本文介紹在IIS上以FastCGI模式運行PHP。咱們以 Windows 2003 + IIS 6.0(windows2003自帶) 爲例。php

第一步:下載安裝的文件

1. FastCGI 版本 fcgisetup_1.5_x86_rtw.msi
2. MySQL 版本 mysql-5.5.19-win32.msi
3. PHP 版本 php-5.3.8-nts-Win32-VC9-x86.ziphtml

提示:
1. 咱們這裏使用目前最新的FastCGI 1.5版本。官方地址
2. Windows下安裝MySQL就選擇.msi安裝包格式,咱們選擇了mysql-5.5.19-win32.msi ,雙擊根據嚮導安裝便可,簡單方便。
3. PHP咱們選擇用php-5.3.8-nts-Win32-VC9-x86.zip這個版本。「vc9」是爲IIS定製的。「nts」是非線程安全版本,針對PHP的FastCGI安裝方式。 mysql

第二步:安裝文件

1. 在要安裝的磁盤建一個文件夾。咱們在D盤的根目錄下建立一個Web文件夾。 D:\Web。
2. 在Web文件夾下建立一個WWW文件夾,用來存放你的PHP網站程序。D:\Web\WWW。
3. 把下載的php-5.3.8-nts-Win32-VC9-x86.zip 解壓到 D:\Web\PHP 文件夾。
4. 安裝MySql數據庫,把MySQL安裝到 D:\Web\MySQL文件夾。具體MySQL安裝過程能夠參考文檔MySQL安裝圖解
5. 爲IIS安裝FastCGI擴展。首先肯定系統已經安裝好了IIS。而後雙擊fcgisetup_1.5_x86_rtw.msi安裝,若是C盤是你的Windows系統安裝盤,它會把fcgi特定的文件複製到 C:\Windows\system32\inetsrv 文件夾下,註冊而且使fcgi的web服務生效,這時在IIS的 「Web服務擴展」 裏多了 FastCGI Handler。web

第三步:配置 IIS

1. 點擊 「控制面板」 -> 「管理工具」 -> 「internet 信息服務」(或者直接點擊「開始」->「運行」->輸入inetmgr.exe),打開IIS。
2. 點擊「網站」->「右鍵-屬性」,在屬性對話欄中點擊「主目錄」->「配置」->「添加」。
3. 在"添加與編輯應用程序擴展名映射」對話框中,點擊瀏覽,找到 C:\Windows\system32\inetsrv 中的fcgiext.dll。擴展名寫上「.php」, 「動做」項中點「限制爲」,寫上「GET,POST,HEAD」,把下面兩個選項 「腳本引擎」、「確認文件是否存在」 都勾上。確認配置。
4. 返回網站屬性框,點擊「文檔」,添加 「index.php」 作爲默認頁。最後點擊「確認」。
5. 點擊「網站」->「右鍵-新建」->「網站」,創建一個新站點,端口咱們這裏設置爲 8080,網站主目錄路徑爲 D:\Web\WWW。sql

第四步:配置FastCGI

在安裝FastCGI後,在C:\Windows\system32\inetsrv文件夾中有如下三個重要文件:數據庫

fcgiext.dll - 這是fastcgi控制柄動態連接庫。它能夠爲與fastcgi進行通訊的程序處理請求。
fcgiext.ini - 這是配置文件,包含擴展到fastcgi進程的文件映射。它也包含了fastcgi進程池的配置。
fcgiconfig.js - 這個配置fastgci的擴展。這個腳本更新fcgiext.ini文件,修改iis元庫,若是有必要的話重複使用web服務應用池。windows

這裏配置FastCGI有兩種方法,一種是經過命令行來實現配置,另外一種直接修改fcgiext.ini文件。api

1. 經過命令行來實現配置瀏覽器

打開命令行,將地址轉換到C:\Windows\system32\inetsrv,輸入如下命令安全

	cscript fcgiconfig.js -add -section:"PHP" -extension:php -path:"D:\Web\php\php-cgi.exe"
	cscript fcgiconfig.js -set -section:"PHP" -InstanceMaxRequests:5000
	cscript fcgiconfig.js -set -section:"PHP" -EnvironmentVars:PHP_FCGI_MAX_REQUESTS:10000
	cscript fcgiconfig.js -set -section:"PHP" -RequestTimeout:360
	cscript fcgiconfig.js -set -section:"PHP" -ActivityTimeout:120

腳本的含義,分別是:

  1. 註冊PHP到FastCGI。
  2. InstanceMaxRequests 用來設置應用程序池回收。FastCGI進程請求數達到InstanceMaxRequests數值5000,應用程序池將自動回收。默認值是1000。
  3. 當環境變量PHP_FCGI_MAX_REQUESTS達到10000將自動回收應用程序池。
  4. RequestTimeout 設置請求超時時間,也就是請求容許的最大時間,若是FastCGI進程請求超過此設置將被禁止,值是90秒。
  5. ActivityTimeout 指定FastCGI進程請求的最大活躍時間,在設定時間內,FastCGI進程和IIS沒有通訊,將終止進程。默認值是70秒。
2. 直接配置fcgiext.ini

打開C:\windows\system32\inetsrv\fcgiext.ini文件,加入

	[Types]
	  php=PHP
	[PHP]
	  ExePath=D:\Web\php\php-cgi.exe

	InstanceMaxRequests=5000
	EnvironmentVars=PHP_FCGI_MAX_REQUESTS:10000
	RequestTimeout=360
	ActivityTimeout=120

提示:「php」 表示擴展名,「PHP」 是配置節名稱,以 「[PHP]」 定義。

把上面代碼複製到fcgiext.ini的末尾,保存就行了。

第五步:配置PHP

打開PHP安裝目錄,即D:\Web\PHP,咱們能夠看到目錄下有兩個這樣的文件 php.ini-development 和 php.ini-production,第一個是開發使用的配置文件,第二個是生產環境的配置,由於咱們是在本機作開發,因此選擇前者。將php.ini-development複製一份到同目錄下,並更名爲 php.ini。這個php.ini 就是當前使用的配置文件,如下幾步都是在修改這個php.ini文件的內容。 另外要注意的是修改php.ini文件後需從新啓動IIS服務,新設置纔會生效。參見文檔:如何重啓IIS服務的方法

1. 設置關於FastCGI部分

找到下面幾行,那前面的引號「;」 去掉,參數設置爲以下

	fastcgi.impersonate = 1
	cgi.fix_pathinfo= 1
	cgi.force_redirect = 0

它們的說明請參考cgi.force-redirectcgi.fix-pathinfofastcgi.impersonate

2. 指定PHP擴展庫的存放目錄

在Windows下PHP的擴展庫一般以 DLL 形式存放在PHP的ext目錄中。
使用文本工具打開php.ini文件,查找extension_dir = "ext",也就是在 On windows 下面那一行。把它前面的分號「;」去除掉,改成以下:

        extension_dir = "D:/Web/PHP/ext"

extension_dir 表示PHP擴展庫的具體目錄,以便調用相應的DLL文件。

3. 開啓相應的擴展庫

默認狀況下許多PHP的擴展庫都是關閉的,好比默認PHP不支持鏈接Mysql數據庫,需開啓相應的擴展庫。
這裏咱們開啓一些經常使用的擴展庫。
查找 ; Windows Extensions(大概在941行),在它的下面是extension列表。
找到以下擴展:

        ;extension=php_curl.dll
        ;extension=php_gd2.dll
        ;extension=php_mbstring.dll
        ;extension=php_exif.dll
        ;extension=php_mysql.dll
        ;extension=php_mysqli.dll
        ;extension=php_pdo_mysql.dll
        ;extension=php_pdo_odbc.dll
        ;extension=php_sockets.dll
        ;extension=php_xmlrpc.dll
        ;extension=php_xsl.dll

把以上extension 前面的分號 「;」 去掉。若是你但願加載其它擴展模塊,方法相同,只要去掉前面的分號便可。
提示1:Exif 擴展是用來顯示圖片的 exif 信息的,由於該擴展須要 mbstring.dll 支持,因此必須將 extension=php_exif.dll 這一行寫到extension=php_mbstring.dll 的後面。
提示2:若是PHP自帶的擴展庫不能知足你的須要,你能夠去 pecl.php.net 查找並下載你須要的庫。windows用戶能夠去 pecl4win.php.net 或者 http://downloads.php.net/pierre/ 下載已經編譯好的DLL文件,也能夠去http://museum.php.net/php5/ 載PECL集合壓縮包。
提示3:不少人在找php_zip.dll,其實從php5.3開始已經集成了zip擴展,你能夠用<?php phpinfo()  ?> 找到zip擴展的說明。

4. 讓PHP支持短標籤

在 php.ini 配置文件查找 short_open_tag = Off (大概在266行)把它修改爲:short_open_tag = On 讓其支持短標籤。
php的代碼通常包含在<?php .... ?>的標籤內,設置 short_open_tag = On 以後,能夠寫成更簡潔的形式:<? .... ?>。

5. 配置PHP的Session功能

在使用session功能時,咱們必須配置session文件在服務器上的保存目錄。咱們須要爲session創建一個可讀寫的目錄,這個目錄最好獨立於網站目錄以外。
這裏把目錄上建在了D:\Web\sessiontmp,而後在 php.ini 配置文件中找 ;session.save_path = "/tmp" (大概在1467行),去掉前面的分號「;」 ,改成以下:

        session.save_path = "D:/Web/sessiontmp"

6. 配置PHP的文件上傳功能

同session同樣,在使用PHP文件上傳功能時,咱們必需要指定一個臨時文件夾以完成文件上傳功能,不然文件上傳功能會失敗。
咱們創建一個可讀寫的目錄文件夾 D:\Web\fileuploadtmp,而後在 php.ini 配置文件中找到 ;upload_tmp_dir = (大概875行),修改成:

        upload_tmp_dir = "D:/Web/fileuploadtmp"

PHP默認上傳文件大小不超過2M,要想上傳大於2M的文件,請參考文檔  配置php.ini實現文件上傳功能

7. 設置時區

在 php.ini 配置文件查找 ;date.timezone = ,去掉前面的分號「;」 改成以下:

	date.timezone = PRC

date.timezone是PHP5.1開始新增長的配置參數,用來設置時區。默認date.timezone是被註釋掉的,也就是默認時區是UTC格林威治標準時間。
咱們這裏改成 date.timezone = PRC(PRC,People’s Republic of China,中華人民共和國),也就是日期使用中國的時區。這樣能夠解決時間相差八小時的問題。

第六步:測試

將以下代碼保存爲index.php文件,放到D:\Web\WWW目錄下面。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
        <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>測試服務器</title>
        </head>
        <body>
            <div style="text-align:center; color:red">
            <?php
                $link=mysql_connect("localhost","你的mysql管理帳號","你的mysql管理密碼");
                if(!$link) echo "MySQL數據庫 鏈接失敗!";
                else echo "MySQL數據庫 鏈接成功!";
                mysql_close();
            ?>
            </div>
            <br/>
            <?php phpinfo(); ?>
        </body>
</html>

而後在瀏覽器地址欄輸入「http://localhost:8080/index.php」。結果以下圖所示:

相關文章
相關標籤/搜索