Logback 将不同的消息记录到两个文件中

Posted

技术标签:

【中文标题】Logback 将不同的消息记录到两个文件中【英文标题】:Logback to log different messages to two files 【发布时间】:2011-01-30 02:54:14 【问题描述】:

我正在使用 logback/slf4j 进行日志记录。我想解析我的日志文件来分析一些数据,所以我不想解析一个大文件(主要由调试语句组成),我想要两个记录器实例,每个记录到一个单独的文件;一个用于分析,一个用于所有目的的日志记录。有谁知道这是否可以通过 Logback 或任何其他记录器实现?

【问题讨论】:

【参考方案1】:

您可以拥有任意数量的记录器。但是,最好为每个需要以不同方式记录的包都有一个。然后该包及其子包中的所有类都将获得该特定记录器。他们都可以共享根记录器并使用 additivity="true" 将他们的日志数据发送到根记录器附加程序。这是一个例子:

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

<property name="pattern" value="%dateHH:mm:ss.SSS %-5p %logger36 
%XakkaSource [%file:%line] - %m%n" />

<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
        <pattern>%dateHH:mm:ss.SSS %-5p %logger36 %XakkaSource [%file:%line] - %m%n</pattern>
    </encoder>
</appender>

<appender name="abc" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>$catalina.base/logs/worker.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <fileNamePattern>$catalina.base/logs/worker-%dyyyy-MM-dd_HH.log</fileNamePattern>
        <maxHistory>360</maxHistory>
    </rollingPolicy>
    <encoder>
        <pattern>$pattern</pattern>
    </encoder>
</appender>

<appender name="xyz" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>$catalina.base/logs/transformer.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <fileNamePattern>$catalina.base/logs/transformer-%dyyyy-MM-dd_HH.log</fileNamePattern>
        <maxHistory>360</maxHistory>
    </rollingPolicy>
    <encoder>
        <pattern>$pattern</pattern>
    </encoder>
</appender>

<logger name="com.xxx.yyy.zzz" level="INFO" additivity="true">
    <appender-ref ref="xyz"/>
</logger>

<logger name="com.aaa.bbb.ccc" level="INFO" additivity="true">
    <appender-ref ref="abc"/>
</logger>

<root>
    <level value="INFO" />
    <appender-ref ref="STDOUT" />
</root>

【讨论】:

【参考方案2】:

就我而言,我想将类名保留为日志名称

private static final Logger log = LoggerFactory.getLogger(ScheduledPost.class);

因为我很少有这样的课程,所以我的logback.xml

<!--additivity=false ensures this log data only goes to the this log, and no one more -->
<logger name="xxx.xxx.xxx.ScheduledPost" level="DEBUG" additivity="false">
    <appender-ref ref="ASYNC_SCHEDULE_LOG_FILE"/>
</logger>
<logger name="xxx.xxx.xxx.GcmPost" level="DEBUG" additivity="false">
    <appender-ref ref="ASYNC_SCHEDULE_LOG_FILE"/>
</logger>
<logger name="xxx.xxx.xxx.PushUtils" level="DEBUG" additivity="false">
    <appender-ref ref="ASYNC_SCHEDULE_LOG_FILE"/>
</logger>

【讨论】:

【参考方案3】:

很可能在 logback 中做这样的事情。这是一个示例配置:

<?xml version="1.0"?>
<configuration>
    <appender name="FILE" class="ch.qos.logback.core.FileAppender">
        <file>logfile.log</file>
        <append>true</append>
        <encoder>
            <pattern>%-4relative [%thread] %-5level %logger35 - %msg %n</pattern>
        </encoder>
    </appender>
    <appender name="ANALYTICS-FILE" class="ch.qos.logback.core.FileAppender">
        <file>analytics.log</file>
        <append>true</append>
        <encoder>
            <pattern>%-4relative [%thread] %-5level %logger35 - %msg %n</pattern>
        </encoder>
    </appender>
    <!-- additivity=false ensures analytics data only goes to the analytics log -->
    <logger name="analytics" level="DEBUG" additivity="false">
        <appender-ref ref="ANALYTICS-FILE"/>
    </logger>
    <root>
        <appender-ref ref="FILE"/>
    </root>
</configuration>

然后您将设置两个单独的记录器,一个用于记录所有内容,另一个用于记录分析数据,如下所示:

Logger analytics = LoggerFactory.getLogger("analytics");

【讨论】:

我需要做这样的事情,这样我就可以有一个无换行符附加程序和一个常规附加程序到同一个文件。感谢您提供此信息。 如果指定了不同的 appender-ref,IMO additivity=false 应该是默认值。我们经常会得到一些应用程序,其中一些模块由于某些计时器事件而非常频繁地生成日志,我们希望将这些日志分离到不同的文件中。在 10 个不同的文件中记录相同的日志确实没有意义。所以它应该是一个选择功能而不是默认功能。由于 logback 是重写的,所以同样的错误应该由同一作者纠正。 我想分别在不同的文件中记录错误、调试、信息消息。是否可以使用 logback.xml @Qasim - 这是可能的。见 - amitstechblog.wordpress.com/2014/09/27/… 我正在尝试将来自不同包的日志记录到不同的文件中,就像这个答案所建议的那样,但这对我不起作用。我的 logback xml 提取在这里 - pastebin.com/Aii4f1Jk。我正在尝试将休眠包 TRACE 级别的日志记录到不同的文件中。有什么建议吗?

以上是关于Logback 将不同的消息记录到两个文件中的主要内容,如果未能解决你的问题,请参考以下文章

spring-logback

logback:两个appender,多个logger,不同级别

logback的MDC机制

Logback SyslogAppender stacktrace 日志记录前缀

通过 Logback 记录到 App Engine request_log

源码详解系列 ------ 全面讲解logback的使用和源码