Log4J RollingFileAppender 在为同一文件创建两个附加程序时不会滚动文件
Log4J RollingFileAppender doesn't roll files when creating two appenders to the same file
虽然我已经阅读了有关此问题的多个其他问题和答案,但我没有找到答案,如果有任何帮助,我将不胜感激。
public static void rerouteAppenderToFile(File file, Logger... log) {
for (Logger logger : log) {
rerouteAppenderToFile(file, logger);
}
}
public static void rerouteAppenderToFile(File file, Logger log) {
log.setAdditivity(false);
log.setLevel(Level.DEBUG);
RollingFileAppender fa = new RollingFileAppender();
fa.setName("RollingFileAppender_" + log.getName());
fa.setMaxBackupIndex(3);
fa.setMaxFileSize("20MB");
File folder = file.getParentFile();
folder.mkdirs();
if (folder.exists() && folder.isDirectory()) {
fa.setFile(file.getAbsolutePath());
fa.setLayout(new PatternLayout(LOGGER_PATTERN));
fa.setThreshold(Level.DEBUG);
fa.setAppend(true);
fa.activateOptions();
log.addAppender(fa);
}
}
我在这里试图实现的是能够使用 RollingFileAppender 将多个记录器(2 个或更多)附加到同一个文件。出于某种原因,文件没有滚动,日志不断变大
问题是您创建了多个写入同一个文件的 RollingFileAppender
。
因此,即使一个 RollingFileAppender
试图滚动到一个新文件,它也不能这样做,因为该文件已被另一个 RollingFileAppender
锁定。
你可以做的是只创建一个 RollingFileAppender
实例并将记录器重新路由到这个实例。
下面的代码给出了思路,但是如果你对一个文件多次调用rerouteAppenderToFile()
是行不通的。
public static void rerouteAppenderToFile(File file, Logger... log) {
RollingFileAppender fa = createAppender(file);
for (Logger logger : log) {
rerouteAppenderToFile(f, logger);
}
}
public static Appender createAppender(File file) {
RollingFileAppender fa = new RollingFileAppender();
fa.setName("RollingFileAppender_" + log.getName());
fa.setMaxBackupIndex(3);
fa.setMaxFileSize("20MB");
File folder = file.getParentFile();
folder.mkdirs();
fa.setFile(file.getAbsolutePath());
fa.setLayout(new PatternLayout(LOGGER_PATTERN));
fa.setThreshold(Level.DEBUG);
fa.setAppend(true);
fa.activateOptions();
return fa;
}
public static void rerouteAppenderToFile(Appender fa, Logger log) {
log.setAdditivity(false);
log.setLevel(Level.DEBUG);
log.addAppender(fa);
}
虽然我已经阅读了有关此问题的多个其他问题和答案,但我没有找到答案,如果有任何帮助,我将不胜感激。
public static void rerouteAppenderToFile(File file, Logger... log) {
for (Logger logger : log) {
rerouteAppenderToFile(file, logger);
}
}
public static void rerouteAppenderToFile(File file, Logger log) {
log.setAdditivity(false);
log.setLevel(Level.DEBUG);
RollingFileAppender fa = new RollingFileAppender();
fa.setName("RollingFileAppender_" + log.getName());
fa.setMaxBackupIndex(3);
fa.setMaxFileSize("20MB");
File folder = file.getParentFile();
folder.mkdirs();
if (folder.exists() && folder.isDirectory()) {
fa.setFile(file.getAbsolutePath());
fa.setLayout(new PatternLayout(LOGGER_PATTERN));
fa.setThreshold(Level.DEBUG);
fa.setAppend(true);
fa.activateOptions();
log.addAppender(fa);
}
}
我在这里试图实现的是能够使用 RollingFileAppender 将多个记录器(2 个或更多)附加到同一个文件。出于某种原因,文件没有滚动,日志不断变大
问题是您创建了多个写入同一个文件的 RollingFileAppender
。
因此,即使一个 RollingFileAppender
试图滚动到一个新文件,它也不能这样做,因为该文件已被另一个 RollingFileAppender
锁定。
你可以做的是只创建一个 RollingFileAppender
实例并将记录器重新路由到这个实例。
下面的代码给出了思路,但是如果你对一个文件多次调用rerouteAppenderToFile()
是行不通的。
public static void rerouteAppenderToFile(File file, Logger... log) {
RollingFileAppender fa = createAppender(file);
for (Logger logger : log) {
rerouteAppenderToFile(f, logger);
}
}
public static Appender createAppender(File file) {
RollingFileAppender fa = new RollingFileAppender();
fa.setName("RollingFileAppender_" + log.getName());
fa.setMaxBackupIndex(3);
fa.setMaxFileSize("20MB");
File folder = file.getParentFile();
folder.mkdirs();
fa.setFile(file.getAbsolutePath());
fa.setLayout(new PatternLayout(LOGGER_PATTERN));
fa.setThreshold(Level.DEBUG);
fa.setAppend(true);
fa.activateOptions();
return fa;
}
public static void rerouteAppenderToFile(Appender fa, Logger log) {
log.setAdditivity(false);
log.setLevel(Level.DEBUG);
log.addAppender(fa);
}