IntelliJ Idea在maven构建后找不到log4j2.xml [英] IntelliJ IDEA won't find log4j2.xml after maven build

查看:28
本文介绍了IntelliJ Idea在maven构建后找不到log4j2.xml的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个带有log4j2(2.9.0)的maven项目和/src/main/java/resources/log4j2.xml中的一个配置文件。只要我留在IntelliJ,它就工作得很好,并且它的日志就像我配置的一样。

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

错误状态记录器未找到log4j2配置文件。使用默认设置 配置:仅将错误记录到控制台。设置系统属性 "log4j2.debug"以显示Log4j2内部初始化日志记录。

只要我在IntelliJ IDEA中创建Build -> Rebuild Project,它就会再次工作。

我真的不明白外部maven构建怎么会混淆IntelliJ的想法,使其不接受本地源代码中的.xml。

有什么想法吗?

推荐答案

我找到了解决方案。

IntelliJ默认情况下将资源复制到/Target/Class,而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>

这篇关于IntelliJ Idea在maven构建后找不到log4j2.xml的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆