我正在使用 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>
java文件启动时出现如下错误 错误 StatusLogger 重新配置失败:在“null”中的“null”处找不到“73d16e93”的配置
我知道“-Dlog4j.configuration=test1.xml”是错误的。 “-Dlog4j.configurationFile=test1.xml”是正确的。但我不明白为什么使用“-Dlog4j.configuration=test1.xml”时会出现错误。
为什么使用-Dlog4j.configuration=test1.xml时会出现错误。
这是因为
log4j.configuration
期望文件位于 classpath 中,而 log4j.configurationFile
(对于 log4j2 为 log4j2.configurationFile
)期望它作为 文件路径。
如果将
-Dlog4j2.debug=true
添加到 VM 参数,您可以看到它正在尝试加载哪个文件并将打印其路径。这样,您就会知道错误发生的原因。
这与我遇到的神秘错误完全相同,因此我将虚拟机参数更新为
-Dlog4j2.configurationFile=
而不是
-Dlog4j.configurationFile=
解决了问题
注意 Dlog4j 中的 22
Log4j 2 对 Log4j 1.2 配置文件提供实验性支持。如果您指定 -Dlog4j.configuration,那么 Log4j 的 ConfigurationFactory 会假定您希望在兼容模式下运行并查找 Log4j 1.x 格式的配置文件。如果您提供了 Log4j2 格式的文件,显然会失败,特别是如果您的项目中没有 log4j-1.2-api,因为 Log4j 1.x XML 配置文件的配置类就在其中。
如果您没有对 xml 文件的写访问权限(库中的错误?理论上您应该只需要读访问权限),则可能会出现此问题。
虚拟解决方法:将此 xml 文件复制到您具有写入访问权限的位置并指向它
在我遇到同样问题的情况下,这是由于指定了不正确的 log4j 文件引起的
不正确 LOGGING_OPTIONS="-Dlog4j.configurationFile=log4j2-sim.xml -Dlog.directory=${STDOUT_DIR}"
正确 LOGGING_OPTIONS="-Dlog4j.configurationFile=log4j2.xml -Dlog.directory=${STDOUT_DIR}"