选错PHP下载包最直接后果是Apache启动失败、phpinfo()不显示或php -v报“Unable to load dynamic library”;关键在于TS/NTS版本须与Web服务器运行模式匹配:Apache+mod_php需TS,其余如Apache/Nginx/IIS+FastCGI或php-fpm均需NTS。

选错 php 下载包最直接的后果是:Apache 启动失败、phpinfo() 不显示、或 php -v 报错 PHP Startup: Unable to load dynamic library。关键不是“哪个更好”,而是“和你的 Web 服务器匹配”。
怎么判断你用的是 TS 还是 NTS 版本?
核心看 Web 服务器的运行模式:
- Apache(Win)+
mod_php(即把 PHP 编译为 Apache 模块加载)→ 必须用Thread Safe (TS)版本 - Apache(Win)+
php-cgi.exe或php-fpm(FastCGI 模式)→ 必须用Non-Thread Safe (NTS)版本 - Nginx(Win/Linux)+
php-fpm→ 只能用NTS版本(php-fpm本身是多进程,非多线程) - IIS(Win)+ FastCGI → 用
NTS;IIS + ISAPI(已废弃)→ 用TS
绝大多数现代 Windows 部署(尤其搭配 Nginx 或新版 Apache 的 CGI/FPM 模式)应默认选 NTS;只有老式 mod_php Apache 安装才需要 TS。
下载页面里 VC15、VC17 是啥?和 TS/NTS 有关系吗?
没有关系,但必须匹配。VC 版本指编译 PHP 所用的 Microsoft Visual C++ 运行库版本:
立即学习“PHP免费学习笔记(深入)”;
-
VC15→ 对应 Visual Studio 2017,需系统安装Visual C++ 2017 Redistributable -
VC17→ 对应 Visual Studio 2022,需安装Visual C++ 2022 Redistributable
如果你的系统没装对应 VC 运行库,启动 php.exe 会直接报错:The code execution cannot proceed because VCRUNTIME140_1.dll was not found. 或类似 DLL 缺失提示。务必先去微软官网下载安装对应 vc_redist 包,再解压使用 PHP。
为什么 php -v 正常但 Apache 不加载?常见配置陷阱
即使选对了 TS/NTS,以下配置错误也会导致模块加载失败:
- Apache 的
httpd.conf中LoadModule php_module路径写错,或指向了 NTS 版本的php8.dll(而你用的是 mod_php 模式) -
PHPIniDir指向了错误目录,或php.ini文件名不是php.ini(比如写成php.ini-development且未重命名) - 扩展路径错误:
extension_dir = "ext"是相对路径,实际要确保该路径下存在php_mysqli.dll等文件,且这些 DLL 本身也必须是同 TS/NTS 版本编译的(混用会崩溃)
LoadModule php_module "C:/php/php8apache2_4.dll" PHPIniDir "C:/php"
注意:php8apache2_4.dll 这个文件只存在于 TS 版本中;NTS 版本不提供此文件,也不能用于 LoadModule。
验证你当前 PHP 是 TS 还是 NTS 的最快方法
运行以下命令,看输出是否含 Thread Safety => enabled:
php -i | findstr "Thread Safety"
或者在 Web 环境中新建一个 info.php:
浏览器打开后搜索 “Thread Safety”,显示 enabled 就是 TS,disabled 就是 NTS。
真正容易被忽略的点是:同一个 PHP 安装包不能混用——TS 版本的 php.exe 无法加载 NTS 的扩展,反之亦然;而很多第三方扩展(如 redis.dll、mongodb.dll)下载页也明确分 TS/NTS,必须严格对应。











