我想允许用户指定他们想要写入Windows事件查看器的级别,但是我也将日志写入控制台和输出文件。有没有办法将所有日志写入文件和控制台,只能将更高级别的日志写入事件查看器,而无需使用两个单独的Logger变量。
private static PatternLayout myLayout
= new PatternLayout("%-4r [%t] %-5p %c %x - %m%n");
// Read from INI file
private static boolean enableWindowsEventLogging;
static final Logger log4jLogger = Logger.getLogger(Main.class);
private static NTEventLogAppender eventLogAppender = new NTEventLogAppender();
private static RollingFileAppender rollingFileAppender;
private static ConsoleAppender consoleAppender = new ConsoleAppender(myLayout);
....
if(enableWindowsEventLogging)
{
switch(Integer.valueOf(thisProperties.getProperty("warningLevel")))
{
case 1: log4jLogger.setLevel(Level.ALL); break;
case 2: log4jLogger.setLevel(Level.FATAL); break;
case 3: log4jLogger.setLevel(Level.ERROR); break;
case 4: log4jLogger.setLevel(Level.WARN); break;
case 5: log4jLogger.setLevel(Level.INFO); break;
case 6: log4jLogger.setLevel(Level.DEBUG); break;
};
// Event viewer logging
log4jLogger.addAppender(eventLogAppender);
}else
log4jLogger.setLevel(Level.OFF);
....
rollingFileAppender = new RollingFileAppender(myLayout,"\\logs\\log4joutput.log", true);
我正在使用Apache log4j 1.2.12
答案 0 :(得分:1)
是的,请记住Logger
的事件是否符合其条件,然后写入记录器的关联Appenders
。
因此,将记录器设置为要从应用程序(DEBUG
)捕获的最低级别,将NT appender设置为更高级别(INFO
),将控制台和文件追加器设置为更低级别(DEBUG
)