2016-11-20 2 views
1

Мне удалось настроить log4j на NetBeans. Я понимаю, цепь приоритета в уровнях и сейчас это подаст свойство конфигурацияlog4j: показать только INFO (не DEBUG) в моем файле журнала

# Root logger option 
log4j.rootLogger=INFO, stdout, file 

# Redirect log messages to console 
log4j.appender.stdout=org.apache.log4j.ConsoleAppender 
log4j.appender.stdout.Target=System.out 
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout 
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n 

# Redirect log messages to a log file, support file rolling. 
log4j.appender.file=org.apache.log4j.RollingFileAppender 
log4j.appender.file.File=F:\\log4j-applicationWS1.log 
log4j.appender.file.MaxFileSize=2MB 
log4j.appender.file.MaxBackupIndex=10 
log4j.appender.file.layout=org.apache.log4j.PatternLayout 
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n 

Я хочу напечатать чистый INFO к console и моей log file? Как я мог это сделать?

+0

Я не понимаю вашу проблему. Я создал новый проект NetBeans, добавил log4j-1.2.17 в качестве зависимости, log4j.properties, как показано выше, и из небольшого основного метода попытался записать 'info()', 'debug()' и 'warn()' Сообщения. На выходе содержались сообщения из 'info()' и из 'warn()' –

+0

приоритет предупреждения выше, чем информация, поэтому сообщения предупреждения также печатаются и на консоли, я не знаю, как пропустить предупреждать сообщения –

ответ

1

Что ваш ищете является LevelRangeFilter:

# Root logger option 
log4j.rootLogger=INFO, stdout, file 

# Redirect log messages to console 
log4j.appender.stdout=org.apache.log4j.ConsoleAppender 
log4j.appender.stdout.Target=System.out 
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout 
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L -- %m%n 
log4j.appender.stdout.filter.a=org.apache.log4j.varia.LevelRangeFilter 
log4j.appender.stdout.filter.a.levelMin=INFO 
log4j.appender.stdout.filter.a.levelMax=INFO 
log4j.appender.stdout.filter.a.acceptOnMatch=true 

# Redirect log messages to a log file, support file rolling. 
log4j.appender.file=org.apache.log4j.RollingFileAppender 
log4j.appender.file.File=log4j-applicationWS1.log 
log4j.appender.file.MaxFileSize=2MB 
log4j.appender.file.MaxBackupIndex=10 
log4j.appender.file.layout=org.apache.log4j.PatternLayout 
log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L -- %m%n 
Смежные вопросы