是否可以在日志消息中引用 MDC 变量,而不是使用 slf4j 和 log4j-impl 的模式?
我有以下代码:
package example;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.slf4j.MDC;
import org.slf4j.MDC.MDCCloseable;
public class Stackoverflow {
private static final Logger log = LoggerFactory.getLogger(Stackoverflow.class);
public static void main(String[] args) {
try (MDCCloseable _unused = MDC.putCloseable("url", "https://google.com/")) {
log.info("blabla some log message url=%mdc{url}");
}
}
}
但是占位符%mdc{url}
不会被替换。
我还尝试使用 %X{url}
和 %MDC{url}
(请参阅 https://logging.apache.org/log4j/2.x/manual/layouts.html )。
当更改 ConversionPattern 以包含这些占位符中的任何一个时,值将被替换。但我想引用消息中的变量而不是模式中的变量。
我的完整 log4j 配置如下所示:
# Root logger option
log4j.rootLogger=INFO, stdout
# Direct log messages to stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target=System.out
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
我使用的是 slf4j 版本 1.7
最佳答案
您想要这样做似乎有点奇怪,因为 MDC 将由日志系统自动打印在您的消息旁边(使其再次打印变得多余),但您可以使用以下方式获取该值MDC.get
:
log.info("blabla some log message url={}", MDC.get("url"));
关于java - 在日志消息中引用 MDC 变量,而不是使用 Slf4j 和 Log4j 的模式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58837432/