日志以将不同的消息记录到两个文件中
我正在使用logback/ slf4j进行日志记录。我想解析我的日志文件来分析一些数据,所以我不想解析一个大文件(主要由调试语句组成),而是希望有两个记录器实例,每个实例都记录到一个单独的文件;一个用于分析,一个用于所有用途的日志记录。有谁知道这是否可能与Logback或任何其他记录器有关?
我正在使用logback/ slf4j进行日志记录。我想解析我的日志文件来分析一些数据,所以我不想解析一个大文件(主要由调试语句组成),而是希望有两个记录器实例,每个实例都记录到一个单独的文件;一个用于分析,一个用于所有用途的日志记录。有谁知道这是否可能与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");
您可以拥有任意数量的记录器。但是,最好为每个需要以不同方式记录的包设置一个。然后,该包及其子包中的所有类都将获得该特定记录器。它们都可以共享根记录器,并使用 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>