我可以使用 Logback.xml 与两个记录器通话吗
Can I Use Logback.xml To Speak to Two Loggers
所以我们有一个有点独特的情况,因为我们有一个公司记录器,它用 LoggerFactory.getLogger 和 class 名称实例化,然后传递一个记录号、可抛出的异常和消息.这将转到公司管理控制台以监控日志。
作为一个团队,我们目前正在使用 logback.xml 将所有日志消息写入文件,以便我们获得额外信息。这是我们的logback.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
<statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener" />
<!-- dev/log/BOSApplication_${byDate}.log -->
<timestamp key="byDate" datePattern="yyyy-MM-dd" />
<appender name="rollingFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!-- <filter class="com.tdameritrade.commons.log.LogSuppressionFilter" /> -->
<!--See also http://logback.qos.ch/manual/appenders.html#RollingFileAppender -->
<File>../logs/BOSApplication_${byDate}.log</File>
<encoder>
<pattern>%date %-5level [%logger{36}:%F.%M:%L - %thread] - %msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- rollover daily -->
<FileNamePattern>../logs/BOSApplication_%d{yyyy-MM-dd}_%i.log </FileNamePattern>
<!-- keep 5 days' worth of history -->
<MaxHistory>5</MaxHistory>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<MaxFileSize>100MB</MaxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
</appender>
<appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%date %-5level [%logger{36}:%F.%M:%L - %thread] - %msg%n</pattern>
</encoder>
</appender>
<appender name="dbAppender" class="com.tdameritrade.commons.log.ApplicationMessagesAppender" />
<root level="INFO">
<appender-ref ref="stdout" />
<appender-ref ref="rollingFile" />
<appender-ref ref="dbAppender" />
</root>
<logger name="org.springframework" level="WARN" />
<logger name="org.springframework.web.servlet.DispatcherServlet" level="INFO" />
<logger name="org.apache.jasper" level="WARN" />
<logger name="springfox.documentation.spring" level="WARN" />
<logger name="org.apache.tomcat.util.net" level="WARN" />
<logger name="org.apache.coyote.http11" level="WARN" />
<logger name="mmAchFulfillmentLogger" level="INFO" additivity="false">
<appender-ref ref="rollingFile" />
<appender-ref ref="stdout" />
</logger>
</configuration>
目前我们必须实例化两个记录器,然后根据消息类型调用一个。
private static final LogManager coreLogManager = new LogManager(AchFulfillmentLoggerUtil.class, "MM_ACH_FULFILLMENT");
private static final Logger mmAchFulfillmentLogger = LoggerFactory.getLogger("mmAchFulfillmentLogger");
有什么方法可以在 logback.xml 中将这两者结合在一起,以便我们可以在 class 中实例化一个日志管理器,然后执行以下操作。
- 如果级别为 ERROR 则调用核心公司记录器和我们的文件记录器
- 如果级别是其他任何级别,请调用我们的文件记录器。
我一直在搜索,但我们的问题似乎有点独特,无法找到答案
A ThresholdFilter
应该没问题:
<appender name="dbAppender" class="com.tdameritrade.commons.log.ApplicationMessagesAppender" >
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>error</level>
</filter>
</appender>
然后清楚地将其附加在适当的记录器和文件记录器下。
所以我们有一个有点独特的情况,因为我们有一个公司记录器,它用 LoggerFactory.getLogger 和 class 名称实例化,然后传递一个记录号、可抛出的异常和消息.这将转到公司管理控制台以监控日志。
作为一个团队,我们目前正在使用 logback.xml 将所有日志消息写入文件,以便我们获得额外信息。这是我们的logback.xml
<?xml version="1.0" encoding="UTF-8"?>
<configuration debug="true">
<statusListener class="ch.qos.logback.core.status.OnConsoleStatusListener" />
<!-- dev/log/BOSApplication_${byDate}.log -->
<timestamp key="byDate" datePattern="yyyy-MM-dd" />
<appender name="rollingFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!-- <filter class="com.tdameritrade.commons.log.LogSuppressionFilter" /> -->
<!--See also http://logback.qos.ch/manual/appenders.html#RollingFileAppender -->
<File>../logs/BOSApplication_${byDate}.log</File>
<encoder>
<pattern>%date %-5level [%logger{36}:%F.%M:%L - %thread] - %msg%n</pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- rollover daily -->
<FileNamePattern>../logs/BOSApplication_%d{yyyy-MM-dd}_%i.log </FileNamePattern>
<!-- keep 5 days' worth of history -->
<MaxHistory>5</MaxHistory>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<MaxFileSize>100MB</MaxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
</appender>
<appender name="stdout" class="ch.qos.logback.core.ConsoleAppender">
<encoder>
<pattern>%date %-5level [%logger{36}:%F.%M:%L - %thread] - %msg%n</pattern>
</encoder>
</appender>
<appender name="dbAppender" class="com.tdameritrade.commons.log.ApplicationMessagesAppender" />
<root level="INFO">
<appender-ref ref="stdout" />
<appender-ref ref="rollingFile" />
<appender-ref ref="dbAppender" />
</root>
<logger name="org.springframework" level="WARN" />
<logger name="org.springframework.web.servlet.DispatcherServlet" level="INFO" />
<logger name="org.apache.jasper" level="WARN" />
<logger name="springfox.documentation.spring" level="WARN" />
<logger name="org.apache.tomcat.util.net" level="WARN" />
<logger name="org.apache.coyote.http11" level="WARN" />
<logger name="mmAchFulfillmentLogger" level="INFO" additivity="false">
<appender-ref ref="rollingFile" />
<appender-ref ref="stdout" />
</logger>
</configuration>
目前我们必须实例化两个记录器,然后根据消息类型调用一个。
private static final LogManager coreLogManager = new LogManager(AchFulfillmentLoggerUtil.class, "MM_ACH_FULFILLMENT");
private static final Logger mmAchFulfillmentLogger = LoggerFactory.getLogger("mmAchFulfillmentLogger");
有什么方法可以在 logback.xml 中将这两者结合在一起,以便我们可以在 class 中实例化一个日志管理器,然后执行以下操作。
- 如果级别为 ERROR 则调用核心公司记录器和我们的文件记录器
- 如果级别是其他任何级别,请调用我们的文件记录器。
我一直在搜索,但我们的问题似乎有点独特,无法找到答案
A ThresholdFilter
应该没问题:
<appender name="dbAppender" class="com.tdameritrade.commons.log.ApplicationMessagesAppender" >
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>error</level>
</filter>
</appender>
然后清楚地将其附加在适当的记录器和文件记录器下。