繁体   English   中英

在 log4j2 中按类名过滤

[英]Filter by class name in log4j2

我正在使用 log4j2,但我不知道如何按类名过滤。 我尝试过使用 RegexFilter,但它只过滤文本消息。 在旧的 log4j 中,带有标签“过滤器”就足够了

<filter class="aaaa.bbbb.cccc.ClassName">

有人知道现在怎么办吗?

先感谢您!

更新:

好的,我做到了! 我需要定义一个记录器并在属性“name”中设置类名:

<loggers>
    <logger name="aaaa.bbbb.cccc.ClassName" additivity="false" level="info">
        <appender-ref ref="RollingFile" />
    </logger>
    <root level="error">
        <appender-ref ref="RollingFile" />
    </root>
</loggers>

如果您遵循记录器的命名约定,这将在 Log4j 中自动工作。 在您的代码中,使用类名声明记录器:

Logger logger = LogManager.getLogger(MyClass.class);

记录器会自动分配一个名称fully.qualified.class.name.of.MyClass 现在,在你的配置,你可以使用这个完全限定域名(或包名称的第一部分)做过滤路由


过滤

下面的示例显示了如何根据执行日志记录的类的包过滤日志事件:包com.other.company中的类的所有DEBUGTRACE级别的日志事件将被忽略,对于包com.another.project类仅包含ERRORFATAL日志记录。

<Configuration status="warn">
  <Appenders>
    <File name="MyFile" fileName="logs/my.log">
      <PatternLayout pattern="%d %p %c{1.} [%t] %m%n" />
    </File>
  </Appenders>
  <Loggers>

    <!-- drops all DEBUG and TRACE logging done by any class in this package -->
    <Logger name="com.other.company" level="INFO" />

    <!-- log only ERROR and FATAL logging by classes in this package -->
    <Logger name="com.another.project" level="ERROR" />

    <!-- by default, all log events are written to MyFile -->
    <Root level="trace">
      <AppenderRef ref="MyFile"/>
    </Root>
  </Loggers>
</Configuration>

路由

下面的例子演示了如何根据包之类的做记录路线记录事件独立的日志文件:在包中的所有记录的类com.other.company将不会被写入到my.log仅向other.log

<Configuration status="warn">
  <Appenders>
    <File name="MyFile" fileName="logs/my.log">
      <PatternLayout pattern="%d %p %c{1.} [%t] %m%n" />
    </File>
    <File name="OtherFile" fileName="logs/other.log">
      <PatternLayout pattern="%d %p %c{1.} [%t] %m%n" />
    </File>
  </Appenders>
  <Loggers>
    <!-- all logging from this package and subpackages goes to OtherFile -->
    <!-- Note: set additivity=false or logging will also go to the root logger -->
    <Logger name="com.other.company" additivity="false">
      <AppenderRef ref="OtherFile"/>
    </Logger>
    <Root level="trace">
      <AppenderRef ref="MyFile"/>
    </Root>
  </Loggers>
</Configuration>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM