仅对文件大小进行日志回滚

时间:2015-02-13 22:25:37

标签: java logback

我正在使用logback 1.0.13。我希望我的日志文件完全基于文件大小滚动。如果这需要2个小时或2年,我不在乎。我无法弄清楚如何这样做。我的appender配置如下:

<appender name="serverFaultFile"
    class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>/folder/to/log/file.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <fileNamePattern>/folder/to/log/file-%d{yyyy-MM}.%i.log</fileNamePattern>
        <MaxHistory>2</MaxHistory>
        <cleanHistoryOnStart>true</cleanHistoryOnStart>
        <timeBasedFileNamingAndTriggeringPolicy
            class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
            <maxFileSize>10MB</maxFileSize>
            <MaxHistory>9</MaxHistory>
        </timeBasedFileNamingAndTriggeringPolicy>
    </rollingPolicy>
    <encoder>
        <pattern>[%p] [%d{ISO8601}] [%c] [%m]%n</pattern>
    </encoder>
</appender>

此解决方案每月滚动,这不是我需要的。我尝试完全删除 - %d {dateformat}修饰符,但后来甚至都没有创建/记录该文件。我尝试了修饰符%G和%yyyy,但每月的结果非常精细,因为logback显然可以让我得到(见bug report)。我错过了什么?

2 个答案:

答案 0 :(得分:8)

你想要一个SizeBasedTriggeringPolicy:http://logback.qos.ch/manual/appenders.html#SizeBasedTriggeringPolicy,可能与FixedWindowRollingPolicy结合使用。

以前是评论,不确定它是否应该得到自己的答案,但现在是这样。 ;)

答案 1 :(得分:5)

只是为了扩展sheltem的答案:

从我的实验中,您必须同时使用FixedWindowRollingPolicySizedBasedTriggeringPolicy,如文档here所示。您似乎无法将SizedBasedTriggeringPolicySizeAndTimeBasedRollingPolicy一起使用,例如:在我的情况下,日志记录无法执行。

xml文件中的典型示例可能是:

<appender name="FILE"
    class="ch.qos.logback.core.rolling.RollingFileAppender">

    <file>../logs/MyProject/testrolling.html</file>

    <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
        <fileNamePattern>../logs/MyProject/backup%i.htm
        </fileNamePattern>
        <minIndex>1</minIndex>
        <maxIndex>10</maxIndex>
    </rollingPolicy>
    <triggeringPolicy
        class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
        <maxFileSize>5MB</maxFileSize>
    </triggeringPolicy>

    <encoder class="...

然后将调用您的备份文件:backup1.htm,backup2.htm等

看起来你不能在fileNamePattern中包含“%d”格式化指令:我尝试过并且记录失败了。但是,根据文档,您必须包含“%i”格式化指令,这是有道理的。

很久以后

这可能是我的天真,但我认为应该设计一个记录应用程序默认生成输出,即总是解释指令,以便至少产生一些东西,而不是什么。