在maven构建之后,IntelliJ IDEA将找不到log4j2.xml

时间:2017-09-18 09:53:23

标签: intellij-idea maven-3 log4j2

我有一个带有log4j2(2.9.0)的maven项目和/src/main/java/resources/log4j2.xml中的配置文件。只要我留在IntelliJ中就可以正常工作,就像我配置它一样记录。

如果我现在在终端(Ubuntu 14)中创建一个mvn clean install,然后在IntelliJ中启动我的程序的main方法,我将收到一个错误,它将找不到log4j2配置文件:

  

ERROR StatusLogger找不到log4j2配置文件。使用默认值   配置:仅将错误记录到控制台。设置系统属性   'log4j2.debug'显示Log4j2内部初始化日志记录。

只要我在IntelliJ IDEA中Build -> Rebuild Project,它就会再次运行。

我真的不明白外部maven构建如何混淆IntelliJ IDEA而不会在本地源代码中使用.xml。

有什么想法吗?

1 个答案:

答案 0 :(得分:1)

我找到了解决方案。

IntelliJ将默认资源复制到/ target / classes,这是IntelliJ实际从中获取log4j2.xml的地方。我的maven构建没有这样做,IntelliJ没有重建项目,因此无法找到log4j2.xml

我的解决方案是将log4j2.xml放在pom的资源部分中:

    <resources>
        <resource>
            <directory>src/main/resources</directory>
            <targetPath>${project.build.directory}/classes</targetPath>
            <includes>
                <include>**/log4j2.xml</include>
            </includes>
        </resource>
    </resources>