我目前正在使用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.