在Log4j2中,如何将XML模式与log4j2.xml相关联?

2022-02-25 00:00:00 java log4j log4j2

我一直在尝试新的Log4j2。从documentation on migration看,XML架构/DTD规范似乎已经废除。

这似乎是一种倒退。当然,应该可以将XML Schema或DTD与MYlog4j2.xml相关联,以帮助编写和验证。我在文档中找不到任何有用的东西,也没有找到XML架构或DTD本身。

SO:在Log4j2中,如何将XML架构与log4j2.xml关联?


解决方案

我认为不可能有带有log4j2的架构/dtd。最近我编写了一个自定义附加器,为了支持该附加器,我的log4j2.xml如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<configuration status="ERROR" packages="package.same.as.custom.appender">
  <appenders>
    <CyclicBuffer name="CyclicBuffer" bufferSize="200">
      <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%t] %c{1.} - %msg%n"/>
    </CyclicBuffer>
  </appenders>
  <loggers>
    <root level="info">
      <appender-ref ref="CyclicBuffer"/>
    </root>
  </loggers>
</configuration>
需要注意的重要一点是,我有一个完全自定义的CyclicBuffer元素,并且它有一个完全自定义的bufferSize属性。有关更多详细信息,请查看有关@PluginFactory@Plugin的文档。

由于这种定制,我不认为可以通过标准的、通用的XSD/DTD来验证XML。相反,如果您希望验证XML,我认为您需要创建自己的XSD。

需要注意的一件重要事情是,我的XML中有:<configuration status="ERROR"。如果出现这种情况,log4j2将在运行时输出与不正确配置相关的任何错误。虽然不如XML验证方便,但它也非常有用!

希望这能有所帮助, --

相关文章