本文主要是记录Windows Server 2003 下Apache以FastCGI方式运行PHP,并升级至PHP5.3.9版本的相关记录,
分为以下四个部分:
1. PHP线程安全与非线程安全版本说明
2. 以FastCGI方式运行PHP相关配置
3. 升级PHP至5.3.9过程中所遇到的问题
4. 总结
说明:本文不涉及MySQL以及php.ini的具体配置。
1. PHP线程安全与非线程安全版本说明
从2000年10月20日发布的第一个Windows版的PHP3.0.17开始的都是线程安全的版本,这是由于与Linux/Unix系统是采用多进程的工作方式不同的是Windows系统是采用多线程的工作方式。如果在IIS下以CGI方式运行PHP会非常慢,这是由于CGI模式是建立在多进程的基础之上的,而非多线程。一般我们会把PHP配置成以ISAPI的方式来运行,ISAPI是多线程的方式,这样就快多了。但存在一个问题,很多常用的PHP扩展是以Linux/Unix的多进程思想来开发的,这些扩展在ISAPI的方式运行时就会出错搞垮IIS。因此在IIS下CGI模式才是 PHP运行的最安全方式,但CGI模式对于每个HTTP请求都需要重新加载和卸载整个PHP环境,其消耗是巨大的。
为了兼顾IIS下PHP的效率和安全,微软给出了FastCGI的解决方案。FastCGI可以让PHP的进程重复利用而不是每一个新的请求就重开一个进程。同时FastCGI也可以允许几个进程同时执行。这样既解决了CGI进程模式消耗太大的问题,又利用上了CGI进程模式不存在线程安全问题的优势。因此,如果是使用ISAPI的方式来运行PHP就必须用Thread Safe(线程安全)的版本;而用FastCGI模式运行PHP的话就没有必要用线程安全检查了,用None Thread Safe(NTS,非线程安全)的版本能够更好的提高效率。
在目前Windows下版本中的PHP官方下载主页上:http://windows.php.net/download/,我们可以看到目前只开放了PHP5.3.9及PHP5.2.17两个版本的下载,并且在5.3.9版本中只提供了VC9 X86运行库的线程安全和非线程安全版本下载,而5.2.17版本中只提供了VC6 X86运行库的线程安全和非线程安全版本下载,那么这两个运行库版本有什么区别呢?简单来说:
VC6版本是使用Visual Studio 6编译器编译的,如果你的PHP是用Apache来架设的,那你就选择VC6版本。
VC9版本是使用Visual Studio 2008编译器编译的,如果你的PHP是用IIS来架设的,那你就选择VC9版本。
本文下载的版本是PHP5.3.9的非线程安全版本,下载地址为:http://windows.php.net/downloads/releases/php-5.3.9-nts-Win32-VC9-x86.zip
2. 以FastCGI方式运行PHP相关配置
首先下载mod_fcgid,下载地址为: http://httpd.apache.org/download.cgi#mod_fcgid,将解压后的mod_fcgid.so放至Apache下的modules目录下;
其次,将下载后的php5.3.9非线程版本解压至 c:/php目录下,配置好php.ini,并复制一份至c:/windows下,修改Apache的配置文件httpd.conf,在最后加入以下配置:
LoadModule fcgid_module modules/mod_fcgid.so
AddHandler fcgid-script .fcgi .php
#php.ini目录
FcgidInitialEnv PHPRC "c:/php"
#设置PHP_FCGI_MAX_REQUESTS大于FcgidMaxRequestsPerProcess,防止php-cgi进程在处理完所有请求前退出
FcgidInitialEnv PHP_FCGI_MAX_REQUESTS 1000
#php-cgi每个进程的最大请求数
FcgidMaxRequestsPerProcess 1000
#php-cgi最大的进程数
FcgidMaxProcesses 3
#脚本超时时间
FcgidIOTimeout 120
FcgidIdleTimeout 120
#php-cgi.exe路径
FcgidWrapper "c:/php/php-cgi.exe" .php
#解析.php文件
AddType application/x-httpd-php .php
最后,去掉节的Options None一行的注释,并修改Options None 为 Options All,保存httpd.conf,并重启Apache服务,升级完成。如下图:
此外,任务管理器中也将会看到php-cgi.exe进程。
3. 升级PHP至5.3.9过程中所遇到的问题
由于网站以前所使用的PHP版本为5.2.17线程安全版本,当时第一反应就是下载PHP5.3.9线程安全版本,并且提前已经安装好了VC++ 2008 SP1运行库,配置好php.ini后重启Apache服务,一直报如下错误:
[warn] pid file C:/Program Files/Apache Software Foundation/Apache2.2/logs/httpd.pid overwritten -- Unclean shutdown of previous Apache run?
始终无法启动成功,在自己本地测试机XP系统下运行正常,无奈之下选择以FastCGI方式来运行PHP(相关配置见上节),如果哪位同学也遇到了这个问题,可以考虑使用FastCGI方式来运行PHP。
4. 总结
遇到问题时多从源头找原因,如果一开始的思路有问题或者说在具体执行过程中行不通,那么可以考虑换一种思路。
希望本文的简单记录对大家有帮助,谢谢:)
顺便截个图,自己设计的:
|