在log4j 1.2到log4j 2迁移中,如何处理DailyRollingFileAppender类?

时间:2015-06-17 05:32:31

标签: java apache logging log4j log4j2

我正致力于将Java项目从使用log4j 1.2迁移到使用log4j 2进行迁移。

log4j 1.x有一个类org.apache.log4j.DailyRollingFileAppender,它在我的项目的log4j.properties配置文件中提到。 log4j中不再存在具有相同名称DailyRollingFileAppender的类2.我想知道DailyRollingFileAppender的角色是否可以被log4j中的某些其他类或某些替换配置或实现替换2.

迁移指南强调应用程序不能访问log4j 1.x内部的方法和类,例如Appender s,因为它可以迁移到log4j 2.但是为了进行迁移,可以是什么完成DailyRollingFileAppender?是否可以通过某些自定义配置或log4j 2中的类组合替换它?有some configuration examples in the migration guide,特别是FileAppender,但是DailyRollingFileAppender呢?它与基本FileAppender

非常接近

来自log4j 1.2 API Javadoc,课程org.apache.log4j.DailyRollingFileAppender

  

DailyRollingFileAppender扩展了FileAppender,以便以用户选择的频率滚动基础文件。据观察,DailyRollingFileAppender会出现同步问题和数据丢失。 log4j extras随附包括应考虑用于新部署的备选方案,并在org.apache.log4j.rolling.RollingFileAppender的文档中进行了讨论。

1 个答案:

答案 0 :(得分:21)

您正在寻找RollingFile appender

<RollingFile name="DAILY_LOG" fileName="log/daily.log"
                 filePattern="log/%d{ddMMyyyy}_daily.log"
                 >
      <PatternLayout pattern="%d [%7r] %5p - %c - %m%n"/>
      <Policies>
        <TimeBasedTriggeringPolicy interval="1"/>
      </Policies>                               
</RollingFile>

前一个样本按天翻转,间隔为1个单位,由文件模式中日期查找的最小单位确定。换句话说,如果日期模式为d{MMyyyy},则interval = 1对应于1个月的翻转期。

请注意,目前不支持限制保留超过特定日期或年龄等的日志文件数。您只能限制每个时间段的日志文件数。