如何使用logback从日志文件中删除最旧的行?

时间:2019-01-09 12:24:26

标签: android file logging filesize max-size

我基于以下解决方案编写了代码:https://gist.github.com/umangmathur92/a65f67c01e2b425289b8

        LoggerContext lc = (LoggerContext) LoggerFactory.getILoggerFactory();
        lc.reset();
        final String LOG_DIR = context.getExternalCacheDir() + File.separator + ".ts";
        RollingFileAppender<ILoggingEvent> rollingFileAppender = new RollingFileAppender<>();
        rollingFileAppender.setAppend(true);
        rollingFileAppender.setContext(lc);
        rollingFileAppender.setLazy(true);
        rollingFileAppender.setFile(LOG_DIR + File.separator + "ts.log");
        SizeBasedTriggeringPolicy<ILoggingEvent> trigPolicy = new SizeBasedTriggeringPolicy<>();
        trigPolicy.setMaxFileSize(new FileSize(1024 * 256));
        trigPolicy.setContext(lc);
        trigPolicy.start();
        FixedWindowRollingPolicy rollingPolicy = new FixedWindowRollingPolicy();
        rollingPolicy.setContext(lc);
        rollingPolicy.setParent(rollingFileAppender);
        rollingPolicy.setFileNamePattern(LOG_DIR + File.separator + "ts.%i.log");
        rollingPolicy.setMinIndex(1);
        rollingPolicy.setMaxIndex(1);
        rollingPolicy.start();
        rollingFileAppender.setTriggeringPolicy(trigPolicy);
        rollingFileAppender.setRollingPolicy(rollingPolicy);
        PatternLayoutEncoder encoder = new PatternLayoutEncoder();
        encoder.setPattern("%msg%n");
        encoder.setContext(lc);
        encoder.start();
        rollingFileAppender.setEncoder(encoder);
        rollingFileAppender.start();
        ch.qos.logback.classic.Logger root = (ch.qos.logback.classic.Logger) LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME);
        root.addAppender(rollingFileAppender);

但这不是我想要做的。这段代码会在达到指定的限制时删除所有文件,并开始写一个新文件(因此,在达到256KB限制文件后,需要10KB )。

我想将文件大小限制为256KB,并且我想清除最旧的行以释放新文件的空间。

示例:

Line 1 sample text.
Line 2 sample text.
Line 3 sample text.
Line 4 sample text.
Line 5 sample text.

想象一下,这些行占用256KB,而当我写新行时:

Line 6 sample text.

我希望该文件的外观如下:

Line 2 sample text.
Line 3 sample text.
Line 4 sample text.
Line 5 sample text.
Line 6 sample text.

1 个答案:

答案 0 :(得分:0)

每当从头开始删除一行时,这将需要重写整个文件。因此,这将成为性能瓶颈。通常的解决方案是在旧日志文件达到一定大小后启动新日志文件。