运维百科

Windows2003下IIS6.0+PHP5+FastCGI环境配置

一、FastCGI
fcgisetup_1.5_rtw_x86.msi(这个是支持IIS6.0的)
下载地址:http://www.iis.net/download/FastCGI  

打开页面后点右边 download x86 / x64 (根据自己的服务器选择下载)


    双击运行进行安装。安装后在 C:\WINDOWS\system32\inetsrv 目录下产生了五个文件。fcgiext.ini文件是它的配置文件,可以直接修改。如图:

    同时在 IIS 的 “Web 服务扩展”里多了 FastCGI Handler。如图:

二、配置FastCGI,注册 PHP 到 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:"c:\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=C:\PHP\php-cgi.exe
InstanceMaxRequests=10000
ActivityTimeout=600
RequestTimeout=600
EnvironmentVars=PHP_FCGI_MAX_REQUESTS:10000,PHPRC:C:\PHP\
php表示扩展名,PHP是配置节名称,以[PHP]定义。 (ExePath=写你自己的安装的目录)


第三步 配置IIS
1、点击 “控制面板” -> “管理工具” -> “internet 信息服务”(或者直接点击“开始”->“运行”->输入inetmgr.exe),打开IIS。
2、点击“网站”->“右键-属性”,在属性对话栏中点击“主目录”->“配置”->“添加”。
3、在"添加与编辑应用程序扩展名映射”对话框中,点击浏览,找到 C:\Windows\system32\inetsrv 中的fcgiext.dll。扩展名写上“.php”, “动作”项中点“限制为”,写上“GET,POST,HEAD”,把下面两个选项 “脚本引擎”、“确认文件是否存在” 都勾上。确认配置。
4.、返回网站属性框,点击“文档”,添加 “index.php” 做为默认页。最后点击“确认”。

5、点击“网站”->“右键-新建”->“网站”,建立一个新站点,端口我们这里设置为80,网站主目录路径为 D:\web\www。


三、配置PHP
下载地址:http://windows.php.net/download/(推荐PHP 5.2.17的ZIP压缩包版本)
          http://museum.php.net/php5/

如何选择PHP5.3的VC9版本和VC6版本
    VC6是什么?
    VC6就是legacy Visual Studio 6 compiler,就是使用这个编译器编译的。
    VC9是什么?
    VC9就是the Visual Studio 2008 compiler,就是用微软的VS编辑器编译的。

那我们如何选择下载哪个版本的PHP呢?
    如果你是在windows下使用Apache+PHP的,请选择VC6版本;
    如果你是在windows下使用IIS+PHP的,请选择VC9版本。
如何选择PHP5.3的Thread Safe和Non Thread Safe版本
    先从字面意思上理解,Thread Safe是线程安全,执行时会进行线程(Thread)安全检查,以防止有新要求就启动新线程的CGI执行方式而耗尽系统资源。Non Thread Safe是非线程安全,在执行时不进行线程(Thread)安全检查。


    再来看PHP的三种执行方式几种方式:
    1、CGI方式加载PHP环境,通常就是IIS里面配置解释器为php.exe,早期比较常见,目前使用较少。
    2、ISAPI方式加载PHP环境,通常就是IIS里面配置解释器为php5isapi.dll,执行方式是以DLL动态库的形式使用,可以在被用户请求后执行,在处理完一个用户请求后不会马上消失,所以需要进行线程安全检查,这样来提高程序的执行效率,所以如果是以ISAPI来执行PHP,建议选择Thread Safe版本。
    3、FastCGI方式加载PHP环境,IIS7.0开始内置FastCGI了,以单一线程来执行操作,所以不需要进行线程的安全检查,除去线程安全检查的防护反而可以提高执行效率,所以,如果是以FastCGI来执行PHP,建议选择Non Thread Safe版本。

    注:微软的说法是 fastcgi使用非线程安全版PHP执行效率会更高,也推荐的是非线程安全版,但是很多商业程序是用zend加密了的,因此按照你的实际情况来下载php包。


    解压php安装,拷贝至C:\PHP。该目录需要给予user读取运行权限
    我们可以看到目录下有两个这样的文件 php.ini-development 和 php.ini-production,第一个是开发使用的配置文件,第二个是生产环境的配置,因为我们是在本机做开发,所以选择前者。将php.ini-development复制一份到同目录下,并改名为 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 = "C:\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 = "C:\WINDOWS\Temp"

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

    同session一样,在使用PHP文件上传功能时,我们必须要指定一个临时文件夹以完成文件上传功能,否则文件上传功能会失败。
我们建立一个可读写的目录文件夹 D:\Web\fileuploadtmp,然后在 php.ini 配置文件中找到 ;upload_tmp_dir = (大概875行),修改为:

upload_tmp_dir = "D:/Web/fileuploadtmp"

    PHP默认上传文件大小不超过2M,要想上传大于2M的文件。

7. 设置时区

    在 php.ini 配置文件查找 ;date.timezone = ,去掉前面的分号“;” 改为如下:

date.timezone = PRC

date.timezone是PHP5.1开始新增加的配置参数,用来设置时区。默认date.timezone是被注释掉的,也就是默认时区是UTC格林威治标准时间。
我们这里改为 date.timezone = PRC(PRC,People’s Republic of China,中华人民共和国),也就是日期使用中国的时区。这样可以解决时间相差八小时的问题。

8. 设置日志

在 php.ini 配置文件查找 ;display_errors = ,去掉前面的分号“;” 改为如下:

display_startup_errors = On

9. 设置日志文件

 在 php.ini 配置文件查找 ;error_log = ,去掉前面的分号“;” 改为如下:

error_log = "D:\Web\PHP\logs\php-errors.log"

10. 设置日志编码

在 php.ini 配置文件查找 ;default_charset = ,去掉前面的分号“;” 改为如下:

default_charset = "utf-8"

10. 禁止FastCGI日志

在 php.ini 配置文件查找 ;fastcgi.logging = ,去掉前面的分号“;” 改为如下:

fastcgi.logging = 0


第六步:测试

将如下代码保存为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/index.php”。结果如下图所示:

本站部分资源收集于网络,纯个人收藏,无商业用途,如有侵权请及时告知!

3
分享到:

评论 0

取消
  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址