【问题标题】:DailyRollingFileAppender not creating daily log fileDailyRollingFileAppender 不创建每日日志文件
【发布时间】:2018-02-15 18:11:12
【问题描述】:

DailyRollingFileAppender 没有创建每日备份日志文件。

我正在使用以下配置,它适用于我的本地机器,但它不适用于部署我的项目的机器。

log4j.rootLogger=DEBUG, Appender2

log4j.appender.Appender2=org.apache.log4j.DailyRollingFileAppender
log4j.appender.Appender2.File=C:/Logs/AppLog.log
log4j.appender.Appender2.DatePattern='.'dd-MM-yyyy
log4j.appender.Appender2.layout=org.apache.log4j.PatternLayout
log4j.appender.Appender2.layout.ConversionPattern=%-7p %d [%t] %c %x - %m%n
log4j.appender.Appender2.rootLogger = DEBUG

框架 - Spring MVC

我无法理解配置的哪一部分阻止 DailyRollingFileAppender 在我的服务器计算机上创建日期明智的日志。

编辑-

我按照建议更新了我的文件,它不会在第二天凌晨 12 点创建新的备份文件。意味着它更新了 AppLog.l‌​og 直到 12 然后没有备份文件并且前一天的所有日志都消失了,它从头开始写入。

这是现在的 log4j 属性-

log4j.rootLogger=DEBUG, Appender2
log4j.appender.Appender2=org.apache.log4j.DailyRollingFileAppender
log4j.appender.Appender2.File=${catalina.home}/Logs/AppLog.log
log4j.appender.Appender2.DatePattern='.'yyyy-MM-dd
log4j.appender.Appender2.layout=org.apache.log4j.PatternLayout
log4j.appender.Appender2.Append=false
log4j.appender.Appender2.layout.ConversionPattern=%-7p %d [%t] %c %x - %m%n

【问题讨论】:

  • 没有不同的属性。我在两台机器上使用相同的代码。

标签: java spring-mvc logging log4j rollingfileappender


【解决方案1】:

你可以用它来获取每日滚动日志文件,

########## Appender Daily Rolling
log4j.logger.appender=Daily
log4j.appender.Daily=org.apache.log4j.DailyRollingFileAppender
log4j.appender.Daily.Threshold=INFO
log4j.appender.Daily.File=D:/backup/RFLI1010.log
log4j.appender.Daily.DatePattern='.'yyyy-MM-dd
# Append to the end of the file or overwrites the file at start.
log4j.appender.Daily.Append=true
log4j.appender.Daily.MaxBackupIndex=20
log4j.appender.Daily.layout=org.apache.log4j.PatternLayout
log4j.appender.Daily.layout.ConversionPattern=  [%5p] %d %r %t (%F:%M:%L)%m%n%n

【讨论】:

  • 试过你的方法,但没有做任何改变。 log4j.appender.Daily.Append 也不应该是假的吗?如果我写的是 true 那么它会附加到同一个文件,对吧?
  • 是的。如果 true 意味着它将附加相同的文件。还分享你的 log4j.property 吗?
  • 我在文件中做了一些更改- llog4j.rootLogger=DEBUG, Appender2 log4j.appender.Appender2=org.apache.log4j.DailyRollingFileAppender log4j.appender.Appender2.File=${catalina.home }/Logs/AppLog.log log4j.appender.Appender2.DatePattern='.'yyyy-MM-dd log4j.appender.Appender2.layout=org.apache.log4j.PatternLayout log4j.appender.Appender2.Append=false log4j.appender .Appender2.layout.ConversionPattern=%-7p %d [%t] %c %x - %m%n
  • 现在它在上午 12 点创建一个新文件,但没有备份文件。表示它从头开始写入同一个文件。
  • log4j.appender.Appender2.Append=true.你是这样检查的吗?
【解决方案2】:

问题在于这里的文件路径:

log4j.appender.Appender2.File=C:/Logs/AppLog.log

请确保此路径存在于您部署项目的服务器上。

【讨论】:

  • 路径存在。代码正在生成一个日志文件。它不会生成每日日期日志。
  • 您使用的是哪个 log4j 版本?
  • 1.2.17 log4jlog4j1.2.17
  • 尝试将日期模式更改为'.'yyyy-MM-dd
  • 也试过了,没用。我用的是Spring MVC框架。有什么特殊设置吗?
【解决方案3】:

我之前遇到过这个问题,原因是我在pom.xml中使用了错误的log4j依赖。之前的依赖是:

<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>

我的项目中使用的是spring boot,所以改成下面这样,就可以了。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-logging</artifactId>
        </exclusion>
    </exclusions>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j</artifactId>
    <version>1.3.8.RELEASE</version>
</dependency>

【讨论】:

  • 我使用的设置与您之前使用的设置相同。你知道 pom.xml 中 Spring-MVC 的依赖关系吗?
  • spring-boot-starter-web如果你使用spring boot,否则声明spring-webmvc就足够了。
【解决方案4】:

【讨论】:

  • 我试过你的方法,还是不行。我使用 Spring MVC 作为我的框架。
猜你喜欢
  • 2018-01-10
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-03-16
  • 1970-01-01
相关资源
最近更新 更多