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

172

我正在使用logback/slf4j进行日志记录。我想解析我的日志文件以分析一些数据,因此我不想解析一个非常大的文件(主要由调试语句组成),我想要有两个logger实例,每个实例都将日志记录到单独的文件中;一个用于分析,一个用于通用日志记录。请问Logback或其他任何记录器是否支持这种功能?

3个回答

335

在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 %logger{35} - %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 %logger{35} - %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");

1
我需要做这样的事情,以便我可以将无换行符的附加器和常规附加器附加到同一个文件中。感谢您提供的信息。 - djangofan
我想将错误、调试和信息消息分别记录在不同的文件中。使用logback.xml可以实现吗? - Qasim
@Qasim - 这是可能的。请参见 - https://amitstechblog.wordpress.com/2014/09/27/logging-different-log-levels-to-different-appenders-with-logback/ - Andy Dufresne
我正在尝试按照这个答案建议的方式将来自不同包的日志记录到不同的文件中,但对我来说并没有起作用。我的logback xml提取在这里 - http://pastebin.com/Aii4f1Jk。我正在尝试将hibernate包的TRACE级别日志记录到另一个文件中。有什么建议吗? - Andy Dufresne
分析工具永远不会打印包名,而是打印 analytics.method 名称。如何在使用字符串作为记录器名称后打印包名? - Prasad
显示剩余2条评论

11

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

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

<property name="pattern" value="%date{HH:mm:ss.SSS} %-5p %logger{36} 
%X{akkaSource} [%file:%line] - %m%n" />

<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
        <pattern>%date{HH:mm:ss.SSS} %-5p %logger{36} %X{akkaSource} [%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-%d{yyyy-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-%d{yyyy-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>

4
在我的情况下,我希望将类名作为日志名称保留。
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>

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接