log4j2- ERROR Appenders 包含无效的元素或属性 "Flume"

标签 log4j log4j2 flume flume-ng

我正在尝试使用 log4j2 的 Flume Appender Properties,但在运行程序时出现以下错误。

  2016-01-20 16:36:42,436 main ERROR Appenders contains an invalid element or attribute "Flume"
    2016-01-20 16:36:42,436 main ERROR Appenders contains an invalid element or attribute "Flume"
    2016-01-20 16:36:42,446 main ERROR Unable to locate appender "eventLogger" for logger config "root"
    2016-01-20 16:36:42,446 main ERROR Unable to locate appender "eventLogger" for logger config "root"

log4j.xml 文件是:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="WARN">
  <Appenders>
    <Console name="Console" target="SYSTEM_OUT">
        <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" />
    </Console>
    <Flume name="eventLogger" compress="false" type="Avro">
        <Agent host="192.168.8.50" port="41414"/>
    </Flume>
  </Appenders>
  <Loggers>
    <Root level="info">
        <AppenderRef ref="Console" />
        <AppenderRef ref="eventLogger" />
    </Root>
  </Loggers>
</Configuration>

在 .java 代码中

LoggerContext context = (org.apache.logging.log4j.core.LoggerContext) LogManager.getContext(false);
File file = new File("src/log4j2.xml");
context.setConfigLocation(file.toURI());

我如何找出问题所在。可能是 log4j2 无法正常工作。

最佳答案

我遇到过类似情况,Appenders下连Appender元素都不识别。解决方法是在配置中添加 strict = "true",如下所示

配置状态="WARN"strict="true"

关于log4j2- ERROR Appenders 包含无效的元素或属性 "Flume",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34897773/

相关文章:

hadoop - 使用水槽获取Twitter数据

java - weblogic log4j.xml 更改记录器的 "level value"(即时)

java - 通过系统属性更改单个类的记录器级别

java - log4j2如何使用多个配置文件

java - Apache 的 ContextMap 是否需要显式清理?

python - Flume 使用 python 套接字或 telnet 时无法正确获取事件

logging - 任何生成高速日志的工具或实用程序

java - 在这种情况下日志记录是如何发生的

c++ - log4cpp - 未处理的异常和访问冲突

log4j2 JsonTemplateLayout 不适用于 Maven 阴影插件