Log4j属性被忽略

时间:2018-11-27 08:27:37

标签: java log4j

我在Eclipse中有标准的Maven项目。我的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文件,因此我尝试在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配置,因为它在其终结器中产生了很多调试输出方法。

谢谢!

2 个答案:

答案 0 :(得分:0)

静态也可能是 rootlogger 未知的问题。 尝试使用

logger=Logger.getLogger(MainScreenApplication.class); 

完成后

 PropertyConfigurator.configure(props)

答案 1 :(得分:0)

log4j中,所有记录器均从父级继承,默认情况下,rootLogger是所有其他记录器的父级,并且为rootLogger定义的追加程序也适用于所有子级记录器。

日志级别,例如ERRORDEBUGFATAL等遵循一个层次结构,这意味着当将附加程序设置为某个级别时,它还将记录所有其他较低的级别超过设定水平层次结构如下: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文件中该特定类的记录器。

如果您要一个类/程序包拥有自己的记录器,则需要对其进行定义。针对您的情况:

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