Log4j RollingFileAppender 的正常行为是在第一条日志消息发生在不同的日期时滚动,但有些人会因为每个日期的空日志文件而感到温暖和模糊,即使没有发生任何事情。有没有办法强制它在午夜之后滚动而不将虚拟消息写入日志?
问问题
5443 次
1 回答
4
我已经非常仔细地查看了这段代码 - 简单的答案是“不”。翻转是作为 Appender 上的 doAppend() 流的一部分触发的——触发它的唯一方法是记录一些东西。
你可以用 cron 来伪造这个:只需让一个 cron 脚本在明天 11:58 触摸文件。这将为您提供您正在寻找的空日志文件行为。
下面是实现翻转功能的代码:
void rollOver() throws IOException {
/* Compute filename, but only if datePattern is specified */
if (datePattern == null) {
errorHandler.error("Missing DatePattern option in rollOver().");
return;
}
String datedFilename = fileName+sdf.format(now);
// It is too early to roll over because we are still within the
// bounds of the current interval. Rollover will occur once the
// next interval is reached.
if (scheduledFilename.equals(datedFilename)) {
return;
}
// close current file, and rename it to datedFilename
this.closeFile();
File target = new File(scheduledFilename);
if (target.exists()) {
target.delete();
}
File file = new File(fileName);
boolean result = file.renameTo(target);
if(result) {
LogLog.debug(fileName +" -> "+ scheduledFilename);
} else {
LogLog.error("Failed to rename ["+fileName+"] to ["+scheduledFilename+"].");
}
try {
// This will also close the file. This is OK since multiple
// close operations are safe.
this.setFile(fileName, false, this.bufferedIO, this.bufferSize);
}
catch(IOException e) {
errorHandler.error("setFile("+fileName+", false) call failed.");
}
scheduledFilename = datedFilename;
}
于 2010-11-03T01:02:16.313 回答