2

我通过在其中添加我自己的 Summary_APPENDER 创建了一个 AsyncAppender。

ASYNC Appender 如下

 <appender name="ASYNC" class="ch.qos.logback.classic.AsyncAppender">
 <discardingThreshold>2</discardingThreshold>
 <appender-ref ref="SUMMARY_APPENDER" />
 <!--   <appender-ref ref="PROCESSING" /> -->
 </appender>

我创建了另一个SUMMARY_APPENDER

<appender name="SUMMARY_APPENDER"
    class="com.my.test.logger.async.MyRollingAppender">
    <file>./logs/summary.log</file>
    <rollingPolicy class="com.my.test.logger.async.MyTimeBasedRollingPolicy">
        <!-- daily rollover -->
        <fileNamePattern>./logs/%d{yyyy-MM-dd,aux}/summary.%d{yyyy-MM-dd}.%i.log
        </fileNamePattern>
        <TimeBasedFileNamingAndTriggeringPolicy
            class="com.my.test.logger.async.MySizeTimeBasedPolicy">
            <maxFileSize>10MB</maxFileSize>
        </TimeBasedFileNamingAndTriggeringPolicy>
        <!-- keep 30 days' worth of history -->
        <maxHistory>30</maxHistory>
    </rollingPolicy>
    <encoder>
        <pattern>
            %d{ISO8601} [%t] %p %c %L - %m%n
        </pattern>
    </encoder>
</appender>

我的自定义附加程序正确扩展了 RollingPolicy。

  • 我已将其导出为带有 logback.xml 的自定义 jar。

  • 我将它添加到新 java 项目的类路径中。

  • 运行一些并发程序来记录,以确保所有线程同时正确地记录它。

程序如下,我创建了 TestLogger1 ,2...5 并运行了它们。

 public class TestingLogger {
 private static Logger log = LoggerFactory.getLogger(TestingLogger.class);
   public static void main(String[] args) {
    LoggerContext lc = (LoggerContext) LoggerFactory.getILoggerFactory();
    StatusPrinter.print(lc);
    for (int i = 1; i < 100000; i++) {
        log.debug(" Testing Logger " + i);
    }
  }
}

每个 Logger 都有 10 万条日志,所以最后我预计有 50 万条

请帮助我了解如何同步日志记录,如果我做错了什么,请告诉我。

4

1 回答 1

7

从手册:

丢弃阈值

默认情况下,当阻塞队列剩余 20% 容量时,它会丢弃 TRACE、DEBUG 和 INFO 级别的事件,只保留 WARN 和 ERROR 级别的事件。要保留所有事件,请将 discardingThreshold 设置为 0。

因此,在您的配置中将此属性从 2 设置为 0,您应该会看到所有消息都到达日志文件中。

于 2013-09-27T08:36:17.720 回答