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

 书友62908490 发布于 2022-12-31 13:54

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

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

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




    C:\temp\logFile.log
    
      C:\temp\logFile.%i.log
      1
      5
    
    
      5KB
    
    
      %-4relative [%thread] %-5level %logger{35} - %msg%n
    


    


我知道maxFileSize触发策略是导致我的日志文件根据文件大小滚动的原因.我无法找到基于程序运行来滚动文件的触发策略.谁能帮我吗?

谢谢!

- 斯蒂芬斯伯丁

1 个回答
  • 以下配置将在每次运行程序时创建新的日志文件(文件名将在其上具有日期戳)和控制台输出,请注意它不使用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>
    

    2022-12-31 13:56 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有