我正在使用 log4j2,jar 文件如下: log4j-api-2.14.0.jar log4j-core-2.14.0.jar log4j-slf4j-impl-2.14.0.jar
执行以下行: LogManager.getLogger("com.foo.Bar1");
使用以下 VM 参数:-Dlog4j.configuration=test1.xml
配置文件 test1.xml 如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">
<Appenders>
<Console name="Console1" target="SYSTEM_OUT">
<PatternLayout
pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
</Console>
<File name="MyFile" fileName="test1.txt">
<PatternLayout>
<Pattern>%d %p %c{1.} [%t] %m%n</Pattern>
</PatternLayout>
</File>
</Appenders>
<Loggers>
<Logger name="com.foo.Bar1" level="trace">
<AppenderRef ref="Console1" />
<AppenderRef ref="MyFile" />
</Logger>
</Loggers>
</Configuration>
Run Code Online (Sandbox Code Playgroud)
java 文件启动时出现以下错误 ERROR StatusLogger Reconfiguration failed: No configuration found for '73d16e93' at 'null' in 'null'
我知道“-Dlog4j.configuration=test1.xml”是错误的。“-Dlog4j.configurationFile=test1.xml”是正确的。但我不明白为什么在使用“-Dlog4j.configuration=test1.xml”时会出现错误。
为什么使用 -Dlog4j.configuration=test1.xml 时会出现错误。
Dan*_*Mor 13
这与我遇到的神秘错误完全相同,因此我将虚拟机参数更新为
-Dlog4j2.configurationFile=
代替
-Dlog4j.configurationFile=
它解决了问题
注意Dlog4j 2中的2
这是因为log4j.configuration期望文件在类路径中,而log4j.configurationFile期望它是文件路径。
如果添加-Dlog4j2.debug=true到 VM 参数,您可以看到它正在尝试加载哪个文件并打印其路径。这样,您将了解错误发生的原因。
Log4j 2 对 Log4j 1.2 配置文件提供实验性支持。如果您指定 -Dlog4j.configuration,那么 Log4j 的 ConfigurationFactory 会假定您希望在兼容模式下运行并查找 Log4j 1.x 格式的配置文件。如果您提供了 Log4j2 格式的文件,显然会失败,特别是如果您的项目中没有 log4j-1.2-api,因为 Log4j 1.x XML 配置文件的配置类就在其中。