0

log4php 配置文档中,有一个名为“additivity”的配置选项可以停止从根记录器继承。

但是,我添加到 PHP 格式的配置文件中,根记录器仍在记录应该只出现在记录器中的条目queryLogger

<?php
return array(
    'rootLogger' => array(
        'level' => 'DEBUG',
        'appenders' => array('fileAppender'),
    ),
    'loggers' => array(
        'queryLogger' => array(
            'level' => 'INFO',
            'appenders' => array('queryFileAppender')
        )
    ),
    'appenders' => array(
        'fileAppender' => array(
            'class' => 'LoggerAppenderDailyFile',
            'layout' => array(
                'class' => 'LoggerLayoutPattern',
                'params' => array(
                    'conversionPattern' => '%d{Y-m-d H:i:s.u} [%-5p] %-100m ---------- [%F:%L]%n'
                )
            ),
            'params' => array(
                'datePattern' => 'Y-m-d',
                'file' => LOG_PATH . 'system-%s.log',
            ),
        ),
        'queryFileAppender' => array(
            'class' => 'LoggerAppenderDailyFile',
            'layout' => array(
                'class' => 'LoggerLayoutPattern',
                'params' => array(
                    'conversionPattern' => '%d{Y-m-d H:i:s.u} %m%n'
                )
            ),
            'params' => array(
                'datePattern' => 'Y-m-d',
                'file' => LOG_PATH . 'query-%s.log',
            ),
        ),
    ),
    'additivity' => array(
        'fileAppender' => false,
    ),
);
?>

我的目标是只登录queryLogger,而不是登录rootLogger。我错过了什么?

4

1 回答 1

2

这可能没有很好的记录,因为除了 INI 方式的过时示例(已弃用)之外,没有关于如何配置可加性的真实示例。

但是查看https://logging.apache.org/log4php/docs/loggers.html的 XML 示例(子章节“禁用 appender 可加性”)显示可加性是记录器本身的设置 - 它不是独立存在的(INI 配置事物的方式让你这么认为)。

通过查看其中的代码,LoggerConfiguratorDefault::configureLogger可以清楚地看出这是一个与单个记录器配置additivity平行level并位于其中的子键。appenders

所以这应该工作:

// ...
'loggers' => array(
    'queryLogger' => array(
        'level' => 'INFO',
        'appenders' => array('queryFileAppender'),
        'additivity' => false
    )
),    //...
于 2013-11-05T21:38:08.480 回答