簡體   English   中英

Log4j屬性被忽略

[英]Log4j properties ignored

我在Eclipse中有標准的Maven項目。 我的log4j.properties文件位於資源文件夾中,如下面的圖像所示。 我還有一個commons-logging.properties文件,用於將可能使用該文件的所有依賴關系定向到log4j配置文件。

項目中的log4j.properties文件

這是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文件似乎沒有自動拾取,因此我嘗試在main方法中強制加載它:

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加載到屬性對象中,即,甚至不遵守日期和時間格式,即使將配置設置為ERROR,它也會打印調試消息。

  • 為什么實際上記錄器沒有遵循log4j配置?

我已經為此爭斗了太長時間了:)我想要使用此功能的原因之一是我正在使用PDFBox,並且希望它也遵循log4j配置,因為它在其finalizer方法中產生了很多調試輸出。

提前致謝!

靜態可能也是rootlogger未知的問題。 嘗試使用

logger=Logger.getLogger(MainScreenApplication.class); 

你做完之后

 PropertyConfigurator.configure(props)

log4j所有記錄器均從父級記錄器繼承,默認情況下, rootLogger是所有其他記錄器的父級,並且為rootLogger定義的附加程序也適用於所有子記錄器。

日志級別(例如ERRORDEBUGFATAL等)遵循一個層次結構,這意味着當將附加程序設置為某個級別時,它還將記錄所有低於該設置級別的所有其他級別。 層次結構如下: FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL 因此,當您將級別設置為ERROR時,將其下的所有其他級別設置為WARN, INFO, DEBUG, TRACE, ALL當您在代碼中要求所有級別時WARN, INFO, DEBUG, TRACE, ALL也會記錄。

為什么實際上記錄器沒有遵循log4j配置? 它正在精確地遵循您的配置。 此行log4j.rootLogger=ERROR, stdout屬性文件中的log4j.rootLogger=ERROR, stdout將rootLogger設置為ERROR級別,並且默認情況下, MainScreenApplication.java的記錄器繼承自rootLogger ,因為您rootLoggerlog4j.properties為此特定類定義任何記錄器log4j.properties文件。

如果要讓一個類/程序包擁有自己的記錄器,則需要對其進行定義。 針對您的情況:

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM