Свойства Log4j игнорируются - PullRequest
0 голосов
/ 27 ноября 2018

У меня есть стандартный проект Maven в Eclipse.Мой файл log4j.properties находится в папке ресурсов, как видно из рисунка ниже.У меня также есть файл commons-logging.properties для направления любых зависимостей, которые могут его использовать, в файл конфигурации log4j.

log4j.properties file in project

Это зависимостив файле gradle.build:

plugins {
  id 'com.github.johnrengelman.shadow' version '2.0.4'
  id 'java'
}

repositories {
    mavenCentral()
}

dependencies {
    compile group: 'net.sourceforge.tess4j', name: 'tess4j', version: '4.2.1'
    compile group: 'org.apache.pdfbox', name: 'pdfbox', version: '2.0.11'
    compile group: 'com.fasterxml.jackson.core', name: 'jackson-databind', version: '2.9.6'
    compile group: 'org.apache.logging.log4j', name: 'log4j-api', version: '2.11.1'
    compile group: 'org.apache.logging.log4j', name: 'log4j-core', version: '2.11.1'
    testImplementation 'junit:junit:4.12'
}

Это содержимое файла log4j.properties:

# Root logger option
log4j.rootLogger=ERROR, stdout

# Direct log messages to stdout
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.properties, похоже, не был выбран автоматически, у меня естьпопытался принудительно загрузить его в основном методе:

private static final Logger logger = Logger.getLogger(MainScreenApplication.class);

public static void main(String[] args) throws IOException {
    Properties props = new Properties();
    props.load(MainScreenApplication.class.getClassLoader().getResourceAsStream("log4j.properties"));
    System.out.println(props);
    PropertyConfigurator.configure(props);
    logger.debug("Starting");
    // Ensure configuration is loaded and stuff copied to user PC
    ConfigurationManager.getInstance().getConfiguration();
    launch(args);
}

Запуск приложения приводит к выводу:

{log4j.rootLogger=ERROR, stdout, 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=org.apache.log4j.ConsoleAppender}
16:10:10.680 [main] DEBUG com.damco.documenthandler.ui.MainScreenApplication - Starting

Очевидно, что log4j.properties загружаются в объект свойства, т.е. датуи формат времени даже не соблюдается, и он печатает отладочное сообщение, даже если конфигурация имеет значение ОШИБКА.

  • Почему регистратор не следует конфигурации log4j?

Я боролся с этим слишком долго :) Одна из причин, по которой я хочу, чтобы это работало, заключается в том, что я использую PDFBox и хочу, чтобы он также следовал конфигурации log4j, поскольку он производит довольно многовывод ebug в методах финализатора.

Заранее спасибо!

Ответы [ 2 ]

0 голосов
/ 27 ноября 2018

В log4j все регистраторы наследуются от родителя, и по умолчанию rootLogger является родителем всех других регистраторов, а добавление, определенное для rootLogger, также применяется ко всем дочерним регистраторам.

Уровни журналирования, такие как ERROR, DEBUG, FATAL и т. Д., Подчиняются иерархии, что означает, что, когда appender установлен на уровень, он также регистрирует все другие уровни, которые ниже установленного уровня.Иерархия выглядит следующим образом: FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL.Поэтому, когда вы устанавливаете уровень на ERROR, все остальные уровни ниже него WARN, INFO, DEBUG, TRACE, ALL также будут регистрироваться, когда вы запрашиваете его в своем коде.

Почему регистратор не следует конфигурации log4j?Это точно соответствует вашей конфигурации.Эта строка log4j.rootLogger=ERROR, stdout в файле свойств устанавливает rootLogger уровня ERROR, и по умолчанию ваш регистратор в MainScreenApplication.java наследуется от rootLogger, так как вы не определили никаких регистраторов для этого конкретного класса в вашем log4j.properties file.

Если вы хотите, чтобы у класса / пакета был собственный регистратор, вам нужно определить его.Для вашей ситуации:

log4j.logger.com.package.to.MainScreenApplication= DEBUG, customAppender
log4j.additivity.com.package.to.MainScreenApplicationt = false #this line is very important as it stops the inheritance from a parent

log4j.appender.customAppender=org.apache.log4j.ConsoleAppender
log4j.appender.customAppender.Target=System.out
log4j.appender.customAppender.layout=org.apache.log4j.PatternLayout
log4j.appender.customAppender.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
0 голосов
/ 27 ноября 2018

static также может быть проблемой, rootlogger неизвестен.Попробуйте использовать

logger=Logger.getLogger(MainScreenApplication.class); 

после того, как вы сделаете

 PropertyConfigurator.configure(props)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...