将WP_DEBUG_LOG设置为true,debug.log中没有显示调试输出,为什么?

时间:2012-12-09 15:12:04

标签: php debugging wordpress

我正在尝试使用WordPress为我正在开发的插件启用基本调试输出。到目前为止,我设法得到了一些,但未能将其重定向到wp-content/debug.log。我一直在大致关注the guide by Douglas Neiner。这是我做的:

我将这段代码添加到wp-config.php

的末尾
@ini_set ('display_errors', 0);
define ('WP_DEBUG', true);
define ('WP_DEBUG_DISPLAY', false);
define ('WP_DEBUG_LOG', true);

我手动创建了debug.log文件,并确保www-data用户可以访问该文件(我在本地运行WordPress,在Ubuntu 12.04上):

septi@norbert:~$ sudo su www-data -c 'ls -l /usr/share/wordpress/wp-content/debug.log'
-rw-rw-r-- 1 root www-data 0 Dec  9 22:12 /usr/share/wordpress/wp-content/debug.log
septi@norbert:~$ sudo su www-data -c 'ls -l /srv/www/localhost/wp-content/debug.log'
-rw-rw-r-- 1 root www-data 0 Dec  9 22:12 /srv/www/localhost/wp-content/debug.log
septi@norbert:~$ sudo su www-data -c 'echo i can write >> /usr/share/wordpress/wp-content/debug.log'
septi@norbert:~$

在插件激活挂钩中添加了一些假设的调试输出语句,以及故意错误:

include ('i fail wp');

register_activation_hook (__FILE__, 'hello_world_activate');

function hello_world_activate()
{
    error_log ('I love debug output when it works!');
}

我期望的是debug.log中缺少的包含文件的错误消息以及“我喜欢调试输出工作时的错误!”消息,页面上没有任何内容。我得到的是页面消息上缺少的包含文件,而debug.log中没有任何内容。但是,调试输出消息并未完全丢失。我在/var/log/apache2/error.log

中找到了它
[Sun Dec 09 22:58:18 2012] [error] [client 127.0.0.1] PHP Warning:  include(i fail wp): failed to open stream: No such file or directory in /usr/share/wordpress/wp-content/plugins/helloworld2085/helloworld2085.php on line 28, referer: http://localhost/wp/wp-admin/plugins.php?deactivate=true&plugin_status=all&paged=1&s=
[Sun Dec 09 22:58:18 2012] [error] [client 127.0.0.1] PHP Warning:  include(): Failed opening 'i fail wp' for inclusion (include_path='.:/usr/share/php:/usr/share/pear') in /usr/share/wordpress/wp-content/plugins/helloworld2085/helloworld2085.php on line 28, referer: http://localhost/wp/wp-admin/plugins.php?deactivate=true&plugin_status=all&paged=1&s=
[Sun Dec 09 22:58:18 2012] [error] [client 127.0.0.1] I love debug output when it works!, referer: http://localhost/wp/wp-admin/plugins.php?deactivate=true&plugin_status=all&paged=1&s=
[Sun Dec 09 22:58:18 2012] [error] [client 127.0.0.1] PHP Warning:  include(i fail wp): failed to open stream: No such file or directory in /usr/share/wordpress/wp-content/plugins/helloworld2085/helloworld2085.php on line 28, referer: http://localhost/wp/wp-admin/plugins.php?deactivate=true&plugin_status=all&paged=1&s=
[Sun Dec 09 22:58:18 2012] [error] [client 127.0.0.1] PHP Warning:  include(): Failed opening 'i fail wp' for inclusion (include_path='.:/usr/share/php:/usr/share/pear') in /usr/share/wordpress/wp-content/plugins/helloworld2085/helloworld2085.php on line 28, referer: http://localhost/wp/wp-admin/plugins.php?deactivate=true&plugin_status=all&paged=1&s=

我怀疑error_log()函数不适合用于输出到debug.log,但我找不到正确的方法。哦,当然我可以硬编码文件路径并附加到它,但是,你知道......

2 个答案:

答案 0 :(得分:3)

error_log()函数写入Web服务器的错误日志(例如/ var / log / httpd / error_log);你想要的是trigger_error()

答案 1 :(得分:2)

我在Fedora 19上的Apache 2.4中运行的WordPress遇到了同样的问题.inror_log()的输出登陆/ var / log / httpd / error_log而不是wp-content / debug.log。 Httpd进程对/ var / www / html / wp-content目录具有写权限(+775),但无法创建wp-content / debug.log文件。

我的wp-config.php调试设置为:

@ini_set(‘display_errors’,0);
define('WP_DEBUG',         true);
define('WP_DEBUG_DISPLAY', false);
define('WP_DEBUG_LOG', true);

事实证明,真正的原因是SELinux。我进行了SELinux策略更改,并允许httpd使用以下命令写入wp-content。 (请参阅SELinux Troubleshooter以获取安装的实际命令)

semanage fcontext -a -t httpd_sys_rw_content_t '/var/www/html/wp-content'
restorecon -v '/var/www/html/wp-content'

此调试消息开始出现在wp-content / debug.log中。