错误 StatusLogger 重新配置失败:在“null”中的“null”处找不到“73d16e93”的配置

问题描述 投票:0回答:5

我正在使用 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时会出现错误。

java xml log4j2
5个回答
66
投票

这是因为

log4j.configuration
期望文件位于 classpath 中,而
log4j.configurationFile
(对于 log4j2 为
log4j2.configurationFile
)期望它作为 文件路径

如果将

-Dlog4j2.debug=true
添加到 VM 参数,您可以看到它正在尝试加载哪个文件并将打印其路径。这样,您就会知道错误发生的原因。


13
投票

这与我遇到的神秘错误完全相同,因此我将虚拟机参数更新为

-Dlog4j2.configurationFile=

而不是

-Dlog4j.configurationFile=

解决了问题

注意 Dlog4j 中的 22


4
投票

Log4j 2 对 Log4j 1.2 配置文件提供实验性支持。如果您指定 -Dlog4j.configuration,那么 Log4j 的 ConfigurationFactory 会假定您希望在兼容模式下运行并查找 Log4j 1.x 格式的配置文件。如果您提供了 Log4j2 格式的文件,显然会失败,特别是如果您的项目中没有 log4j-1.2-api,因为 Log4j 1.x XML 配置文件的配置类就在其中。


1
投票

如果您没有对 xml 文件的写访问权限(库中的错误?理论上您应该只需要读访问权限),则可能会出现此问题。

虚拟解决方法:将此 xml 文件复制到您具有写入访问权限的位置并指向它


0
投票

在我遇到同样问题的情况下,这是由于指定了不正确的 log4j 文件引起的

不正确 LOGGING_OPTIONS="-Dlog4j.configurationFile=log4j2-sim.xml -Dlog.directory=${STDOUT_DIR}"

正确 LOGGING_OPTIONS="-Dlog4j.configurationFile=log4j2.xml -Dlog.directory=${STDOUT_DIR}"

© www.soinside.com 2019 - 2024. All rights reserved.