如何解决某些版本的 PHP
我按照我写的 this guide 安装了多个版本的 PHP。 基本上,它是一个 ApacheLounge 安装,通过 Windows 10 上的 FastCGI 与 PHP 对话。 这曾经让我在不同的 VirtualHosts 上同时运行这些 PHP 版本。 Apache 在这些端口上通过 FastCGI 调用正确的 PHP 版本:
- PHP 5.2.17 端口 9052
- PHP 5.3.29 端口 9053
- PHP 5.4.45 端口 9054
- PHP 5.5.38 端口 9055
- PHP 5.6.40 端口 9056
- PHP 7.0.33 端口 9070
- PHP 7.1.33 端口 9071
- PHP 7.2.31 端口 9072
- PHP 7.3.19 端口 9073
- PHP 7.4.7 端口 9074
一切 其中一些在安装后已经工作了一段时间。昨天我不得不在 PHP 5.6 上测试一个网站,但输出只是一个“没有指定输入文件的消息”,结果证明它没有那么多描述性,作为 quick google search confirmed。
所以我开始了一个系统的方法。 我为每个 PHP 版本创建了一个 VirtualHost,只有一个带有 echo 语句的 index.php 文件。 我测试了所有安装的PHP版本,所有PHP5版本都无法运行,而PHP7版本则正常。
我删除了所有自定义配置文件。没有变化。
我提供了一个简单的 index.html 文件,它适用于所有 VirtualHosts。关于 PHP,没有变化。
我以为是 PHP 5.x 的错误,但在我重新启动 PC 后,PHP 5.2 版本开始工作。 我停止、删除并重新安装了一些通过 NSSM 创建的 Windows 服务,没有任何变化。
这就是我认为我知道的:
- 这不是 PHP 5.x 的问题,因为 PHP 5.2 可以工作;
- 这不是FastCGI的问题,因为除了端口号外,所有VirtualHosts都具有相同的配置;
- 这不是 Apache 配置问题,因为它会启动、停止、重启和服务;
- 这不是PHP配置问题,因为所有配置都是标准的;
- 这不是 .htaccess 配置问题,因为没有 .htaccess 文件;
对如何调试此配置或出现问题的任何想法表示赞赏。
谢谢。
解决方法
这个答案是关于我在上面发现的问题,以及它是如何为我工作的。
在 this post 和网络上的其他地方,我发现将 doc_root
留在 php.ini
中的建议已注释掉:
;doc_root =
这是可行的,事实上,这是我用于所有上述 PHP 7.x 安装以及 PHP 5.2 的配置。但是,这不适用于 PHP 5.3 到 5.6。
实际情况是,对于这些版本的 PHP,Apache 的 DocumentRoot
和 PHP 的 doc_root
指令必须完全匹配。
到达这里并不容易,因为我在网上发现了大量欺骗性或明显错误的信息(主要是由于 PHP 的行为从版本到版本的变化):
-
this (unsolved) bug report 有一个类似的问题,有一个 user comment 建议将
doc_root
注释掉; -
this paragraph 是矛盾的;
-
PHP 的文档对于那些特定版本是错误的,对于当前版本是正确的:
在Description of core php.ini directives:
Name Default Changeable doc_root NULL PHP_INI_SYSTEM
和Where a configuration setting may be set:
PHP_INI_SYSTEM Entry can be set in php.ini or httpd.conf
我希望这些信息有用。
注意:
我花了很多时间来解决这个问题。我发现一种有用的技术是将 Apache 日志级别增加到 trace8,如suggested here:
LogLevel trace8
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。