记录不符合级别的多个记录器

时间:2016-08-07 17:15:39

标签: java logging logback

我已将logback.xml定义为:

<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">

    <jmxConfigurator />

    <appender name="ROOT_FILE_APPENDER"
        class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder class="net.logstash.logback.encoder.LogstashEncoder">
            <fieldNames>
                <timestamp>timestamp</timestamp>
                <version>[ignore]</version>
                <levelValue>[ignore]</levelValue>
            </fieldNames>
        </encoder>
        <file>root.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <fileNamePattern>root.%d{yyyy-MM-dd}.%i.log.gz</fileNamePattern>
            <maxFileSize>$100MB</maxFileSize>
            <totalSizeCap>1GB</totalSizeCap>
            <maxHistory>7</maxHistory>
        </rollingPolicy>
    </appender>

    <appender name="basic-text" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder>
            <pattern>%X{Logging-CorrelationId} %d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
        </encoder>
        <file>text.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <fileNamePattern>text.%d{yyyy-MM-dd}.%i.log.gz</fileNamePattern>
            <maxFileSize>100MB</maxFileSize>
            <totalSizeCap>1GB</totalSizeCap>
            <maxHistory>7</maxHistory>
        </rollingPolicy>
    </appender>

    <root level="ERROR">
        <appender-ref ref="ROOT_FILE_APPENDER" />
    </root>

    <logger name="it.pkg.testpkg.service" additivity="true" level="INFO">
        <appender-ref ref="basic-text"/>
    </logger>

</configuration>

请注意,“root”记录器级别已设置为“ERROR”,另一个记录器级别已设置为“INFO”且additivity = true。

我的java类包含如下代码:

private static final Logger LOGGER = LoggerFactory.getLogger(it.pkg.testpkg.service.EchoService.class);

现在,问题是,当我执行日志记录时:

LOGGER.info("Test Log");

日志条目同时包含在两个日志文件中,即使根记录器级别已设置为“ERROR”。但是,此刻,我摆脱了“it.pkg.testpkg.service”记录器(通过注释或删除它),该条目停止进入root logger。我不太确定这里发生了什么。

目前,我已通过在“ROOT_FILE_APPENDER”中添加以下条目找到了临时解决方案:

<filter class="ch.qos.logback.classic.filter.LevelFilter">
     <level>ERROR</level>
     <onMatch>ACCEPT</onMatch>
     <onMismatch>DENY</onMismatch>
</filter>

但是,我不希望我的appender与特定的日志级别绑定。这是Logback的错误,或者,我在这里做错了什么。

我正在使用以下pom依赖项:

<dependency>
    <groupId>net.logstash.logback</groupId>
    <artifactId>logstash-logback-encoder</artifactId>
    <version>4.7</version>
</dependency>

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-access</artifactId>
    <version>1.1.7</version>
</dependency>

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.1.7</version>
</dependency>
<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-core</artifactId>
    <version>1.1.7</version>
</dependency>

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>jcl-over-slf4j</artifactId>
    <version>1.7.21</version>
</dependency>

<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.21</version>
</dependency>

任何帮助都将不胜感激。

感谢。

1 个答案:

答案 0 :(得分:1)

通过additivity到达的祖先记录器的行为会跳过日志级别检查。

如果你的记录器

<logger name="it.pkg.testpkg.service" additivity="true" level="INFO">
    <appender-ref ref="basic-text"/>
</logger>

接受日志声明

LOGGER.info("Test Log");

然后相应的输出将被发送到它的祖先记录器,无论该记录器的日志级别如何。

您始终可以将additivity设置为false并将根文件追加器添加到记录器中

<logger name="it.pkg.testpkg.service" additivity="false" level="INFO">
    <appender-ref ref="basic-text"/>
    <appender-ref ref="ROOT_FILE_APPENDER" />
</logger>