PHP关于VC11,VC9,VC6以及Thread Safe和Non Thread Safe版本选择的问题(这是个巨坑)

warning: 这篇文章距离上次修改已过1612天,其中的内容可能已经有所变动。

有的,小伙伴,第一次打开php官方下载页面时不是所措被水淹没

我滴天那该下哪一个啊?


官网上的php安装包有VC11或VC9到底是啥意思啊?

其实VC11或VC9是指编译器的版本
  • VC6版本是使用Visual Studio 6编译器编译的,如果你的PHP是用Apache来架设的,那你就选择VC6版本。(现在PHP已经没有VC6了)。
  • VC9意思就是该版本PHP是用VisualStudio2008编译的,而VC11则是用VisualStudio2012编译的。这意味着
  • 如果你下载的是VC9版本的,就需要先安VisualC++RedistributableforVisualStudio2008SP1,
  • 如果你下载的是VC11版本的,就需要先安VisualC++RedistributableforVisualStudio2012.
  • 搭建php首先看操作系统的版本,如果是Windows的在这里下:http://windows.php.net/download/

选择32位还是64位?

如果是32位的,就选择带“x86”的版本,如果是64位的,就选择带“x64”的版本。一般32位只能用32位,64位可以用32位或64位,但建议用64位。 看到这里一定又有小伙伴会问了我咋知道是用32位还是64位?
  • 主要看系统版本想XP就是32位的,至于其他的系统 在计算机上右击属性,你会看到你的系统是多少位的。

是“Non Thread Safe”还是“Thread Safe”?

“Non Thread Safe”中文翻译是非线程安全,“Thread Safe”中文翻译是线程安全,当然并不是“Thread Safe”的版本更好更安全。

首先先扯点无关紧要的东西

首先从Linux/Unix与windows说起
  • Linux/Unix系统是采用CGI(多进程)工作方式。
  • Windows系统是采用ISAPI(多线程)工作方式。

      也就是说Linux/Unix是许多人干活,而Windows是一个人干许多活,但是毕竟大多数的服务器是运行Linux/Unix,说以php主要是以CGI方式运行的。如果在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进程模式不存在线程安全问题的优势。

先从字面意思上理解,Thread Safe是线程安全,执行时会进行线程(Thread)安全检查,以防止有新要求就启动新线程的CGI执行方式而耗尽系统资源。Non Thread Safe是非线程安全,在执行时不进行线程(Thread)安全检查。

   因此,如果是使用ISAPI的方式来运行PHP就必须用ThreadSafe(线程安全)的版本;而用FastCGI模式运行PHP的话就没有必要用线程安全检查了,用None Thread Safe(NTS,非线程安全)的版本能够更好的提高效率。

再来看PHP的两种执行方式:ISAPI和FastCGI。

       ISAPI执行方式是以DLL动态库的形式使用,可以在被用户请求后执行,在处理完一个用户请求后不会马上消失,所以需要进行线程安全检查,这样来提高程序的执行效率,所以如果是以ISAPI来执行PHP,建议选择Thread Safe版本;

       而FastCGI执行方式是以单一线程来执行操作,所以不需要进行线程的安全检查,除去线程安全检查的防护反而可以提高执行效率,所以,如果是以FastCGI来执行PHP,建议选择Non Thread Safe版本。

反正记住:看WEB服务器是什么?如果是IIS系列,就选择带“Non Thread Safe”的版本,如果是Apache httpd系列,就选择带“Thread Safe”的版本。

*注:IIS是微软的互联网基本服务,可以发布网页,和apache功能在大方面上差不多,都是发布网页的
 

说到这还得注意一点,apache毕竟是开源的软件,所以Apache httpd还要看这个二进制版本是怎么编译的。

apache有三种编译类型,分别是:VC6、VC9、VC11(分别代表Visual C++ 6、Visual C++ 2008、Visual C++ 2012)。这里就有麻烦了:PHP官方的最新版本5.5已经用VC11编译,5.4是用VC9编译的。可是Apache httpd的最新版本呢,至今还是用VC6编译。

这发生了一个恐怖的事情:Apache httpd的官方版本和PHP的官方版本竟然是无法兼容的!

    那现有的Windows下的Apache+PHP是怎么搞的呢?可以自己用VC11编译Apache httpd,但这太折腾了,PHP官方建议下载第三方打包好的Apache httpd版本,推荐了这个站点:http://www.apachelounge.com/download/

需要说明一点:这个VC11不支持XP,如果你用的是XP,那么最高只能升级到5.4.24,5.5是用VC11编译的,而VC11不支持XP和2003。

如果是Linux系的在这里下载PHP的源码:http://cn2.php.net/downloads.php

与上面Windows版不同的是,这里下载到的不能直接用,只是PHP的源码,要安装需要自己编译,要编译就需要安装gcc、make等一堆编译软件。看到文档里说./configure、make、make install,针对的就是PHP的源码版本而言。

自己编译php就更麻烦了,你就不会编译  依赖的库一大堆,等着人掉进去的坑也有一大堆。

如果嫌麻烦,可以找已经编译好的版本,具体的说就是各个发行版的官方的软件库。

下面以流行的ubuntu系和centos系为例分别说明;

deb包管理式(ubuntu、Debian)

用apt-cache search php命令可以搜出很多结果,我们需要是“php5”,完整的命令是:apt-get install php5

这显然不是永远适用的,因为命令中有版本号5,未来PHP6是什么情况谁也不知道。

如果想在shell中安装一个命令行的php引擎,就安装这个包

apt-getinstall php5-cli

RPM包管理(Fedora、RedHat、SUSE、CentOS)

yuminstall php

如果是php命令行,就安装yuminstall php-cli

   

评论已关闭