PHP线程安全与非线程安全的区别:如何选择用哪一个?
很多时候,我们在做PHP环境配置的时候,很多人都是直接去乱下载PHP版本的,但是他不清楚:从2000年10月20日发布的第一个Windows版的PHP3.0.17开始的都是线程安全的版本,直至5.2.1版本开始有Thread Safe(TS,线程安全)和None Thread Safe(NTS,非线程安全)之分。
目前最和PHP搭配最主流的几种web服务:
1、IIS
2、Apache
3、Nnginx
目前PHP运行的方式有以下几种:
- IIS:Internet Information Services (互联网信息服务),是由微软公司提供的基于运行Microsoft Windows的互联网基本服务
- CGI:Common Gateway Interface (通用网关接口),是外部应用程序(CGI程序)与Web服务器之间的接口标准
- ISAPI:Internet Server Application Programming Interface (互联网应用程序接口),是为Microsoft所提的Internet server的API
- FastCGI:CGI存在收到每个请求时都开辟一个进程等不足,FastCGI可以理解为是征对CGI的改进版
一、 PHP线程安全与非线程安全的区别:
因为:Linux/Unix系统采用的是多进程的工作方式,而Windows系统采用多线程的工作方式。
即:Linux系统的任务调度基本单位是进程,Windows系统的任务调度基本单位是线程;
此图代表:
PHP:32位非安全线程、32位安全线程、34位非安全线程、34位安全线程
一般我们会把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,非线程安全)的版本能够更好的提高效率。
二、我应该如何选择用哪一个(PHP线程安全、PHP非线程安全)?
windos服务器:
1、如果你是PHP+IIS;请选择:PHP非线程安全(None Thread Safe(NTS));
2、如果你是PHP+apache;请选择:PHP线程安全(Thread Safe(TS))
linux服务器:
linux服务器下的PHP,没有PHP线程安全和非线程安全版的区分;
三、TS和NTS是什么意思?
TS是指具有多线程能力的构建。NTS是指单线程构建。
TS二进制文件的用例涉及与作为模块加载到Web服务器的多线程SAPI和PHP进行交互。
对于NTS二进制文件,广泛的用例是通过FastCGI协议与Web服务器进行交互,不使用多线程(也可以是CLI)。