首頁  >  文章  >  後端開發  >  IIS下使用FastCGI模式運行PHP

IIS下使用FastCGI模式運行PHP

WBOY
WBOY原創
2016-08-08 09:33:311327瀏覽

IIS下使用FastCGI模式運行PHP

由於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:WebWWW。
3. 把下載的php-5.3.8-nts-Win32-VC9-x86.zip 解壓縮到 D:WebPHP 資料夾。
4. 安裝MySql資料庫,把MySQL安裝到 D:WebMySQL資料夾。具體MySQL安裝過程可以參考文件MySQL安裝圖解。
5. 為IIS安裝FastCGI擴充。首先確定係統已經安裝好了IIS。然後雙擊fcgisetup_1.5_x86_rtw.msi安裝,如果C盤是你的Windows系統安裝盤,它會把fcgi特定的文件複製到C:Windowssystem32inetsrv 資料夾下,註冊並且使fcgi的web服務生效,這時在IIS的「Web服務擴充」 裡多了FastCGI Handler。

第三步:配置 IIS

1. 點選 「控制台」 -> 「管理工具」 -> 「internet 資訊服務」(或直接點選「開始」->「執行」->輸入inetmgr.exe),開啟IIS。
2. 點選“網站”->“右鍵-屬性”,在屬性對話欄中點選“主目錄”->“設定”->“新增”。
3. 在"新增與編輯應用程式副檔名對應」對話方塊中,點選瀏覽,找到 C:Windowssystem32inetsrv 中的fcgiext.dll。副檔名寫上“.php”, “動作”項目中點“限制為”,寫上“GET,POST,HEAD”,把下面兩個選項 “腳本引擎”、“確認檔案是否存在” 都勾上。確認配置。
4. 返回網站屬性框,點選“文件”,新增 “index.php” 做為預設頁。最後點選「確認」。
5. 點擊“網站”->“右鍵-新建”->“網站”,建立一個新站點,連接埠我們這裡設定為 8080,網站主目錄路徑為 D:WebWWW。

第四步:設定FastCGI

在安裝FastCGI後,在C:Windowssystem32inetsrv資料夾中有以下三個重要檔案:

fcgiext.dll - 這是fastcgi控制柄動態連結函式庫。它可以為與fastcgi進行通訊的程序處理請求。
fcgiext.ini - 這是一個設定文件,包含擴展到fastcgi進程的文件映射。它也包含了fastcgi進程池的配置。
fcgiconfig.js - 這個配置fastgci的擴充。這個腳本更新fcgiext.ini文件,修改iis元庫,如果有必要的話重複使用web服務應用程式池。

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

1. 透過命令列來實現配置

開啟命令列,將位址轉換到C:Windowssystem32inetsrv,輸入以下命令

	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:windowssystem32inetsrvfcgiext.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-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扩展,你可以用 找到zip扩展的说明。

4. 让PHP支持短标签

在 php.ini 配置文件查找 short_open_tag = Off (大概在266行)把它修改成:short_open_tag = On 让其支持短标签。
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>
            <?php
                $link=mysql_connect("localhost","<em>你的mysql管理账号</em>","<em>你的mysql管理密码</em>");
                if(!$link) echo "MySQL数据库 连接失败!";
                else echo "MySQL数据库 连接成功!";
                mysql_close();
            ?>
            </div>
            <br/>
            <?php phpinfo(); ?>
        </body>
</html>

然后在浏览器地址栏输入“http://localhost:8080/index.php”。结果如下图所示:

以上就介绍了IIS下使用FastCGI模式运行PHP,包括了FastCGI模式方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn