如何在Netbeans maven项目中将log4j2.xml添加到类路径中

时间:2016-09-24 10:54:10

标签: java maven netbeans log4j2

我目前正在使用sl4fj和log4j2在Netbeans中编写一个小型Maven Java应用程序。在生产环境中部署时,我无法使用java属性log4j.configurationFile。因此,我希望log4j2搜索并找到我的项目中的属性文件。我已经google了一下,没有运气,尝试了以下选项;

将log4j2.xml添加到src / main / resources文件夹,并使用maven配置(pom.xml)将其包含在jar中。这实际上不包含在类路径中,而是将xml添加到类路径中的某个位置。

<build>
        <resources>
            <resource>
                <directory>src/main/resources</directory>
                <targetPath>com/reddipped/jsonlogger_2</targetPath>
                <includes>
                    <include>log4j2.xml</include>
                </includes>
            </resource>
        </resources>
</build>

更改了项目属性中的类路径 - &gt; actions-&gt;运行项目以包含xml文件

exec.args=-classpath %classpath:/Users/petervannes/NetBeansProjects/JSONLogger_2/log4j2.xml ${packageClassName}

我可以尝试其他任何选项吗?它是一个maven项目,因此无法在项目属性中添加jar。

- 更新1 -

我在pom.xml中添加了属性maven.test.additionalClasspath,包括log4j2.xml。并添加了一个简单的JUnit测试。

<properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>1.6</maven.compiler.source>
        <maven.compiler.target>1.6</maven.compiler.target>         
<maven.test.additionalClasspath>${project.basedir}/src/test/java/log4j2.xml</maven.test.additionalClasspath>
</properties>

执行Maven clean并使用-X参数进行构建时,日志报告

properties used {java.vendor=Oracle Corporation, sun.java.launcher=SUN_STANDARD ....., maven.test.additionalClasspath=/Users/petervannes/NetBeansProjects/JSONLogger_2/src/test/java/log4j2.xml, maven.compiler.target=1.6

仍然收到找不到log4j配置文件的错误。

Running com.reddipped.test.JSONLoggerTest
ERROR StatusLogger No log4j2 configuration file found. Using default configuration: logging only errors to the console.

1 个答案:

答案 0 :(得分:0)

This page描述了log4j用于查找配置的方法。

根据这一点,您应该将log4j2.xml文件放在项目的默认包中。