In log4j 1.2 to log4j 2 migration, what to do with the DailyRollingFileAppender class?(在从log4j 1.2迁移到log4j 2的过程中,如何处理DailyRollingFileAppender类?)
问题描述
我正在将Java项目从使用log4j 1.2进行日志记录迁移到使用log4j 2。
log4j1.x有一个类org.apache.log4j.DailyRollingFileAppender
,我的项目的log4j.properties配置文件中提到了这个类。log4j 2中不再存在同名的类DailyRollingFileAppender
。我想知道DailyRollingFileAppender
的角色是否可以由log4j 2中的某些其他类或某些替换配置或实现替换。
迁移指南强调,应用程序不得访问log4j 1.x内部的方法和类(如),才能与log4j 2兼容。但是,要进行迁移,可以对DailyRollingFileAppender
做些什么?是否可以用一些自定义配置或log4j2中的类组合来替换它?有some configuration examples in the migration guide,特别是有一个FileAppender
,但是DailyRollingFileAppender
呢?它相当接近基本的FileAppender
:
来自log4j 1.2 API Javadoc,类org.apache.log4j.DailyRollingFileAppender
DailyRollingFileAppender扩展FileAppender,以便以用户选择的频率滚动底层文件。观察到DailyRollingFileAppender出现同步问题和数据丢失。Log4jExtras附带包括新部署时应考虑的备选方案,并在org.apache.log4j.rolling.RollingFileAppender.文档中进行了讨论
推荐答案
您正在寻找RollingFile附加器
<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}
,则间隔=1对应于1个月的滚动周期。
请注意,当前不支持限制超过特定日期或日期等保留的日志文件数。您只能限制每个时间段的日志文件数。
这篇关于在从log4j 1.2迁移到log4j 2的过程中,如何处理DailyRollingFileAppender类?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在从log4j 1.2迁移到log4j 2的过程中,如何处理DailyRollingFileAppender类?
基础教程推荐
- 在螺旋中写一个字符串 2022-01-01
- Java 中保存最后 N 个元素的大小受限队列 2022-01-01
- 如何使用 Eclipse 检查调试符号状态? 2022-01-01
- 由于对所需库 rt.jar 的限制,对类的访问限制? 2022-01-01
- 如何使用 Stream 在集合中拆分奇数和偶数以及两者的总和 2022-01-01
- 首次使用 Hadoop,MapReduce Job 不运行 Reduce Phase 2022-01-01
- 如何强制对超级方法进行多态调用? 2022-01-01
- Spring Boot Freemarker从2.2.0升级失败 2022-01-01
- 如何在不安装整个 WTP 包的情况下将 Tomcat 8 添加到 Eclipse Kepler 2022-01-01
- 如何对 HashSet 进行排序? 2022-01-01