是否可以更改WP_DEBUG_LOG的日志文件位置?


18

我在开发环境中使用WP_DEBUG_LOG,而wp-content目录中的debug.log没有任何问题。

有时,当我需要调试某些产品时,我会在生产环境中打开WP_DEBUG,而我仍想使用该日志,但希望将其重定向到Web根目录之外的某个位置。使用WP_DEBUG_LOG是否可能?

Answers:


19

事实证明,WP_DEBUG_LOG所做的全部是:

ini_set( 'log_errors', 1 );
ini_set( 'error_log', WP_CONTENT_DIR . '/debug.log' );

因此,如果要在插件或主题中更改WP_DEBUG_LOG的日志位置,则Webaware的答案是最好的。如果您只想在其中进行更改,则wp-config.php可以替换define( 'WP_DEBUG_LOG', true );为以上两行,然后将日志文件更改为所需的位置。


几年后,除非它位于wordpress内容文件夹中,否则我似乎无法使该文件充满错误。
Mike Kormendy

@MikeKormendy-可能是目录权限问题。您希望写入文件的位置必须是php运行程序进程所有者的用户可写。简而言之,请确保新文件目标与当前wp-content文件夹具有相同的权限。
Michael Teter


4

是的,如果您向插件或主题的functions.php中添加一些代码,如下所示:

if (defined('WP_DEBUG_LOG') && WP_DEBUG_LOG) {
    ini_set( 'error_log', WP_CONTENT_DIR . '/debug.txt' );
}

编辑:其他人只是向我提出了这样做的需要,因此我将一些代码放入了一个他们可以编辑的简单插件中;如果有人需要,它可以作为要点


我尝试将其添加到我的wp-config.php文件中,但它不起作用。是因为wp-config.php可能早于使用WP_DEBUG_LOG定义日志文件的代码中的实际位置加载了?
jjeaton

1
通过将其添加到mu插件中,我能够使它正常工作。无论如何,我只需要在wp-config中进行此更改?我假设我只需要将WP_DEBUG_LOG设置为false并替换自己的内容?
jjeaton

1
如果您可以将代码放在插件或主题中,则效果很好,谢谢!
jjeaton

是的,只需将其转储到一个简单的插件中即可。请参阅在Codex上编写插件
webaware

1

自该问题的最后答案发布以来,WordPress代码似乎已更改。当前与这些常量相关的wp_debug_mode()函数包括一个测试,以确定WP_DEBUG_LOG等于true还是1-在这种情况下,它的行为与其他人所描述的相同。

但是,您也可以将该常量设置为字符串(您的首选文件路径),日志将在那里输出。例如,您可以将其设置为目录之外的路径,以供公众访问Web内容。您可能必须使用文件权限才能正常工作。

我之所以要寻找这个答案,是因为WordFence安全插件抱怨说我的调试日志可能在/ wp-content /中可以访问

if ( in_array( strtolower( (string) WP_DEBUG_LOG ), array( 'true', '1' ), true ) ) { $log_path = WP_CONTENT_DIR . '/debug.log'; } elseif ( is_string( WP_DEBUG_LOG ) ) { $log_path = WP_DEBUG_LOG; } else { $log_path = false; }


0

Afaik,您不能更改默认调试文件的位置。您可以更改的是MU错误日志的位置以及PHP错误日志文件的位置。

$ds = DIRECTORY_SEPARATOR;
# DEBUG
define( 'WP_DEBUG',               true );
// file: ~/WP_CONTENT_DIR/debug.log
define( 'WP_DEBUG_LOG',           true );
define( 'WP_DEBUG_DISPLAY',       true );
define( 'SAVEQUERIES',            true );
# DEBUG: MU
define( 'DIEONDBERROR',           true );
define( 'ERRORLOGFILE',           WP_CONTENT_DIR.$ds.'logs'.$ds.'mu_error.log' );

@ini_set( 'log_errors',           'On' );
# PHP Error log location
@ini_set( 'error_log',            WP_CONTENT_DIR.$ds.'logs'.$ds.'php_error.log' );

因此,我需要关闭WP_DEBUG_LOG才能确保在我的wp-content目录中从未创建debug.log文件?
jjeaton

1
您现在正在这个时代问很多问题:)我现在不在脑海中回答这些问题。明天回来聊天吧。
kaiser

0

时间在变化,所以对技术问题的正确答案也应如此。

截至2019年末的当前答案很简单。现在,在wp-config.php中定义WP_DEBUG_LOG“ constant”时,您可以提供要写入文件的路径。

define( 'WP_DEBUG_LOG', '/tmp/wp-errors.log' );

请参阅Wordpress支持文档

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.