Windows下IIS以FastCGI模式運行PHP

來源:互聯網
上載者:User

標籤:style   http   io   color   ar   os   使用   sp   for   

由於PHP5.3 的改進,原有的IIS 通過isapi 方式解析PHP指令碼已經不被支援,PHP從5.3.0 以後的版本開始使用微軟的 fastcgi 模式,這是一個更先進的方式,運行速度更快,更穩定。本文介紹在IIS上以FastCGI模式運行PHP。我們以 Windows 2003 + IIS 6.0(windows2003內建) 為例。

第一步:下載安裝的檔案

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.zip

提示:
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安裝方式。 

第二步:安裝檔案

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。

第三步:配置 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。

第四步:配置FastCGI

在安裝FastCGI後,在C:\Windows\system32\inetsrv檔案夾中有以下三個重要檔案:

fcgiext.dll - 這是fastcgi控制項控點動態連結程式庫。它可以為與fastcgi進行通訊的程式處理請求。
fcgiext.ini - 這是設定檔,包含擴充到fastcgi進程的檔案對應。它也包含了fastcgi進程池的配置。
fcgiconfig.js - 這個配置fastgci的擴充。這個指令碼更新fcgiext.ini檔案,修改iis元庫,如果有必要的話重複使用web服務應用池。

這裡配置FastCGI有兩種方法,一種是通過命令列來實現配置,另一種直接修改fcgiext.ini檔案。

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:5000cscript fcgiconfig.js -set -section:"PHP" -EnvironmentVars:PHP_FCGI_MAX_REQUESTS:10000cscript fcgiconfig.js -set -section:"PHP" -RequestTimeout:360cscript 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.exeInstanceMaxRequests=5000EnvironmentVars=PHP_FCGI_MAX_REQUESTS:10000RequestTimeout=360ActivityTimeout=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 = 1cgi.fix_pathinfo= 1cgi.force_redirect = 0

它們的說明請參考cgi.force-redirect;cgi.fix-pathinfo;fastcgi.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”。結果如所示:

Windows下IIS以FastCGI模式運行PHP

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.