代码之家  ›  专栏  ›  技术社区  ›  Aly

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

  •  128
  • Aly  · 技术社区  · 15 年前

    我正在使用logback/slf4j进行日志记录。我想解析我的日志文件来分析一些数据,所以我不想解析一个大文件(主要由调试语句组成),而是希望有两个记录器实例,每个实例都记录到一个单独的文件中;一个用于分析,一个用于所有用途的日志记录。有没有人知道使用logback或任何其他日志记录程序是否可能做到这一点?

    3 回复  |  直到 7 年前
        1
  •  260
  •   Tuna Valknut    10 年前

    在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");
    
        2
  •  3
  •   AraT    7 年前

    你可以有任意多的伐木工人。但是,最好为每个需要以不同方式登录的包提供一个。然后,该包及其子包中的所有类都将获得特定的记录器。它们都可以共享根记录器,并使用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>
    

        3
  •  2
  •   treehouse    7 年前

    在我的例子中,我想把类名保留为日志名

    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>