每次运行java程序时如何使用logback来滚动日志文件

时间:2014-07-30 20:02:20

标签: java logback

我有一个小的java程序,它将作为最终用户的jar文件运行'桌面。这个小程序有一个特定的任务要完成,它是作为一个简单的java程序运行(不是swing或类似的东西)。

我想使用logback来捕获此程序的输出,我希望每次运行程序时都会滚动日志文件。换句话说,程序第一次运行时,我想要生成一个名为c:\ temp \ logFile.log的日志文件。程序第二次运行时,我希望将第一个日志文件重命名为logFile.1.log并创建一个新的logFile.log。程序第三次运行时,我希望将第一个日志文件重命名为logFile.2.log,将第二个日志文件重命名为logFile.1.log,并创建一个新的logFile.log。我希望最多有5个存档文件。

到目前为止,我已经能够根据文件大小配置回滚以滚动日志文件。我已经得到它来完全重命名日志文件的方式,并保持准确的档案数量。问题是我不希望日志文件滚动文件大小,我希望它在每次程序运行时滚动。我该怎么做呢?这是我到目前为止在logback.xml文件中得到的内容:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<appender name="fileAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
    <file>C:\temp\logFile.log</file>
    <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
      <fileNamePattern>C:\temp\logFile.%i.log</fileNamePattern>
      <minIndex>1</minIndex>
      <maxIndex>5</maxIndex>
    </rollingPolicy>
    <triggeringPolicy class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
      <maxFileSize>5KB</maxFileSize>
    </triggeringPolicy>
    <encoder>
      <pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>
    </encoder>
</appender>
<root level="info">
    <appender-ref ref="fileAppender" />
</root>
</configuration>

我知道maxFileSize触发策略是导致我的日志文件根据文件大小滚动的原因。我无法找到基于程序运行来滚动文件的触发策略。任何人都可以帮助我吗?

谢谢!

-Stephen Spalding

1 个答案:

答案 0 :(得分:6)

以下配置将在每次运行程序时创建一个新的日志文件(文件名上都有日期戳)和控制台输出,请注意它不使用RollingFileAppender。有关更多信息,请参阅logback文档https://logback.qos.ch/manual/configuration.html

<configuration>
    <timestamp key="bySecond" datePattern="yyyyMMdd'T'HHmmss"/>
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <layout class="ch.qos.logback.classic.PatternLayout">
            <Pattern>%d{HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</Pattern>
        </layout>
    </appender>
    <appender name="FILE" class="ch.qos.logback.core.FileAppender">
        <file>logfile-${bySecond}.txt</file>
        <append>true</append>
        <encoder>
            <Pattern>%d{HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n</Pattern>
        </encoder>
    </appender>
    <root level="info" additivity="false">
        <appender-ref ref="STDOUT"/>
        <appender-ref ref="FILE"></appender-ref>
    </root>
</configuration>