Windows 上可装多个 PHP 版本,但须用 ZIP 免安装包+路径隔离+手动切换 PATH;MSI 安装包会覆盖注册表、环境变量及服务,导致版本错乱、扩展加载失败。

Windows 上装多个 PHP 版本是可行的,但不能靠官方 MSI 安装包直接实现——它们会互相覆盖注册表、环境变量和系统服务。真正稳定可用的方式是「免安装版(Thread Safe ZIP)+ 手动隔离路径 + 环境变量切换」。
为什么不能用官方 MSI 安装多个 PHP?
MSI 安装器默认写入 HKEY_LOCAL_MACHINE/SOFTWARE/PHP,且会覆盖 php.exe 的全局路径;即使改安装路径,php.ini 加载逻辑、扩展 DLL 依赖、以及 Apache/Nginx 模块绑定仍极易冲突。实测中,2 个 MSI 版本共存后,php -v 显示版本错乱、extension_dir 指向错误路径、openssl 或 curl 扩展直接报 DLL 加载失败。
推荐方案:ZIP 包 + 独立目录 + 切换 PATH
从 windows.php.net/download 下载线程安全(TS)ZIP 包(如 php-8.1.29-Win32-vs16-x64.zip),解压到互不嵌套的路径,例如:
C:/php/8.1C:/php/8.2C:/php/8.3
每个目录下确保包含:php.exe、php.ini-development(重命名为 php.ini)、ext/ 文件夹。修改各 php.ini 中的 extension_dir 为绝对路径,例如:
立即学习“PHP免费学习笔记(深入)”;
extension_dir = "C:/php/8.2/ext"
不设全局 PATH,而是按需在终端中临时设置:
set PATH=C:/php/8.2;%PATH% php -v
或用批处理封装切换逻辑(避免手敲):
@echo off set PHP_HOME=C:/php/8.2 set PATH=%PHP_HOME%;%PATH% php %*
CLI 使用时容易忽略的三个坑
很多用户切完 PATH 后仍执行旧版本,原因常出在:
- 终端未重启:CMD/PowerShell 启动时已缓存原
PATH,改完要新开窗口 - IDE 内置终端未同步:VS Code 的集成终端需关掉再开,或手动运行
Refresh Environment Variables插件 -
php.ini被误读:用php --ini查看实际加载路径,确认不是读了C:/Windows/php.ini或其他残留配置
Web 服务器如何绑定指定 PHP 版本?
Apache 和 Nginx 不通过系统 PATH 调用 PHP,而是硬编码解释器路径。以 Apache 的 httpd.conf 为例:
LoadModule php_module "C:/php/8.2/php8apache2_4.dll" PHPIniDir "C:/php/8.2"
Nginx 配合 PHP-FPM 时,则在 nginx.conf 的 fastcgi_pass 指向对应版本的 FPM 实例:
location ~ /.php$ {
fastcgi_pass 127.0.0.1:9001; # 8.2 版本的 fpm 监听端口
}
每个 PHP 版本需单独启动其 php-fpm.exe(需先复制一份 php.ini 并修改 pid、error_log、listen 端口),否则端口冲突或日志混写。
多版本 PHP 在 Windows 上不是“装完就用”,关键在于路径隔离、配置文件归属明确、以及 Web 服务与 CLI 的调用路径完全解耦。最容易出问题的不是安装步骤,而是后续忘记哪个终端绑了哪个版本,或者 php.ini 改了没 reload 服务。
