log4j 重写DailyRollingFileAppender 自定义日志文件名
背景
我们要对非当日的日志进行压缩,运维要求日志文件后缀必须是xxx.log 这种格式的,但是非当天日志文件后缀,比如今天是20230414,那么20230413的日志后缀 DailyRollingFileAppender默认的是 xxx.log.2023-04-13,这样就不满足压缩规则,所以我们必须要改成xxx_2023-04-13.log这种格式的。
重写的话,首先需要看看人家本身是怎么实现的
DailyRollingFileAppender 源码
主要看一下两个方法就可以。
activateOptions() 会初始化一个scheduledFilename 文件名称,会根据设置的文件名称+datePattern(默认值为datePattern = “'.'yyyy-MM-dd”)
public void activateOptions() {
super.activateOptions();
if (this.datePattern != null && this.fileName != null) {
this.now.setTime(System.currentTimeMillis());
this.sdf = new SimpleDateFormat(this.datePattern);
int type = this.computeCheckPeriod();
this.printPeriodicity(type);
this.rc.setType(type);
File file = new File(this.fileName);
this.scheduledFilename = this.fileName + this.sdf.format(new Date(file.lastModified()));
} else {
LogLog.error("Either File or DatePattern options are not set for appender [" + this.name + "].");
}
}
rollOver() 为定期的执行,判断当天文件名和scheduledFilename 是否相等,看是否需要重写文件后缀名
void rollOver() throws IOException {
if (this.datePattern == null) {
this.errorHandler.error("Missing DatePattern option in rollOver().");
} else {
String datedFilename = this.fileName + this.sdf.format(this.now);
if (!this.scheduledFilename.equals(datedFilename)) {
this.closeFile();
File target = new File(this.scheduledFilename);
if (target.exists()) {
target.delete();
}
File file = new File(this.fileName);
boolean result = file.renameTo(target);
if (result) {
LogLog.debug(this.fileName + " -> " + this.scheduledFilename);
} else {
LogLog.error("Failed to rename [" + this.fileName + "] to [" + this.scheduledFilename + "].");
}
try {
this.setFile(this.fileName, true, this.bufferedIO, this.bufferSize);
} catch (IOException var6) {
this.errorHandler.error("setFile(" + this.fileName + ", true) call failed.");
}
this.scheduledFilename = datedFilename;
}
}
}