繁体   English   中英

log4j2 class 使用除 root 之外的多个记录器时的名称

[英]log4j2 class name when using multiple loggers besides root

我正在使用 log4j2。 我已经定义了多个记录器,因此,我的 log4j2.xml 看起来像:

   <Property name="LOG_PATTERN">[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n</Property>
   ...
   ...
   <Loggers>
        <Logger name="trace" level="INFO" additivity="false">
            <AppenderRef ref="console" />
        </Logger>
        <Logger name="error" level="ERROR" additivity="false">
            <AppenderRef ref="errorLog" />
        </Logger>
        <Logger name="warn" level="WARN" additivity="false">
            <AppenderRef ref="warnLog" />
        </Logger>
   </Loggers>

然后我从代码中调用它们。 片段:

Class myclass{
...

    Logger LOGGER1 = LogManager.getLogger("trace");
    Logger LOGGER2 = LogManager.getLogger("error");
...
     LOGGER1.trace("whatever message");

我的问题是,据我所知,从代码调用记录器时,我可以从 log4j2.xml 中指定记录器。 例如,如果我想使用“trace logger”,我可以编写 LogManager.getLogger("trace")

然后,当“打印日志”时,%c{1} 不再是类名,而是记录器名......在这个例子中,log4j2 将打印为 %c “trace” 而不是 “myclass”(即我想要的是)。

我想知道,有没有可能:

  • 选项 1. 调用具体记录器,同时打印“真实”类名(不是在 getLogger 方法中作为参数传递的类名),
  • 选项 2. 在 gerLogger 方法中使用类名,并将此记录器从代码映射到来自 log4j2.xml 的记录器

提前感谢您的线索。

在 log4j2.xml 文件中,定义日志模式时,您可以使用两个不同的东西:“c”(小写)和“C”(大写)。

  1. “c”将作为记录器名称记录,并且
  2. “C”将作为 class 记录在其中创建记录器(执行 %M 的类)。

包括第二个的可能模式如下所示:

<Property name="LOG_PATTERN">[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] [%C][%M] - %msg%n</Property>

更多信息在这里: http://logging.apache.org/log4j/2.x/manual/usage.html#LoggerVsClass

不管怎样,之前https://stackoverflow.com/users/1709216/rgoers提出的文章,都是金矿。

您的问题听起来好像您还没有阅读 log4j 文档或阅读任何有关如何使用它的文章。 特别是,您应该查看:

<Property name="LOG_PATTERN">[%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] [%C][%M] - %msg%n</Property>

c - 用于 output 日志事件的类别。 例如,对于类别名称“abc”,模式 %c{2} 将为 output “bc”。

C - 用于 output 发出记录请求的调用者的完全限定 class 名称。 例如,对于 class 名称“org.apache.xyz.SomeClass”,模式 %C{1} 将为 output“SomeClass”。

暂无
暂无

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

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