xdebug.ini 和 php.ini 有什么区别

What's the difference between xdebug.ini and php.ini

最近我在 ubuntu 16.04 机器上安装了 lamp 和 php-xdebug。我注意到现在我有以下文件

/etc/php/7.0/apache2/conf.d/20-xdebug.ini

/etc/php/7.0/cli/conf.d/20-xdebug.ini

/etc/php/7.0/mods-available/xdebug.ini

我在想这些文件之间有什么区别,/etc/php/7.0/apache2/php.ini 中的设置受这些影响。

另外,就最佳实践而言,应该使用这些文件中的哪些?

如果在这些文件中使用不同的值重复配置,哪个优先?

例如,如果 xdebug.remote_port = 9000/etc/php/7.0/apache2/php.ini 中设置,在 /etc/php/7.0/mods-available/xdebug.ini 中设置为 xdebug.remote_port = 9001 将选择哪个值?

Ubuntu 基于 Debian。 Debian 及其衍生产品使用某种独特的方式来管理 php 和 apache 的扩展。

在您列出的文件中:

  • /etc/php/7.0/apache2/conf.d/20-xdebug.ini 是 /etc/php/7 的符号链接.0/mods-available/xdebug.ini

  • /etc/php/7.0/cli/conf.d/20-xdebug.ini 也是 [=58= 的符号链接.0/mods-available/xdebug.ini

  • 您可以直接编辑 /etc/php/7.0/mods-available/xdebug.ini,您所做的更改将影响所有启用它的地方。

命令 phpenmodphpdismod 可用于启用或禁用 [​​=71=] 模块。这些类似于 apache 的 a2enmod,您可以阅读 here。例如,使用 sudo phpdismod xdebug 关闭 XDebug。使用 sudo phpenmod xdebug 将其重新打开。当您打开和关闭它时,您的配置将被保留,因为您的更改总是保留在 mods-available 中,尽管 PHP 不会在该目录中查找配置。事实上,当您 "disable" 带有 phpdismod 的模块时,它只是从适当的文件夹中删除符号链接,这样模块就不会在 php 配置中启用。

最后,/etc/php/7.0/apache2/php.ini 是系统范围配置的位置,它不是可以启用或禁用的模块。


因此,您的配置更改 xdebug.remote_port = 9000 应该放在 /etc/php/7.0/mods-available/xdebug.ini 中,因为它与 XDebug 相关。把它放在两个地方是个坏主意(因为它会造成混乱),但最后一个加载优先。这就是为什么 mods-available 目录中的许多文件在文件名中都有数字 - 所以它们会以正确的顺序加载。

使用 phpinfo() 函数获取有关加载了哪些配置值以及从哪些 ini 文件加载的更多信息。例如:

$ php -r "phpinfo();"

$ php -r "phpinfo();" | grep xdebug

这取决于how PHP was compiled。通过查看正在加载的 .ini 文件列表以及从何处加载文件,了解 PHP 是如何编译的。

在命令行中,键入以下内容并查看:

$ php -i | grep .ini

或者,您可以通过创建临时 PHP 文件并在浏览器中访问它来了解这一点。请务必将其命名为难以找到的名称,并在完成后立即将其删除;例如,/info-949w30.php。为什么?因为此报告可能会泄露完整的文件系统路径、版本号和其他详细信息。

<?php phpinfo();

PHP 有两个在编译时建立的指令。

  • --with-config-file-path=path/to/main.ini
  • --with-config-file-scan-dir=/scan/this/dir/for/other.ini 个文件。

首先加载主.ini文件,然后按字母顺序加载扫描目录中的文件。这就是为什么您会看到很多 .ini 文件使用数字前缀。这是控制加载顺序的简单方法。更改与目录中其他文件相关的文件名。