Log4j2程序性消息替换(替换log4j中的PatternLayout)

2022-04-12 00:00:00 logging java log4j log4j2 slf4j

我们正在将日志从log4j迁移到log4j2。但是,我在迁移扩展了PatternLayout的类时遇到了问题,因为它现在是final

旧模式布局代码将 的所有匹配项替换为|,如果它是堆栈跟踪,则除外。

我查阅了log4j2的文档,但还没有找到很好的解决这种问题的方法。到目前为止,我认为这不可能使用XML配置,而只能使用Java代码。

如果满足条件,我们如何替换日志字符串中的某些字符?

有什么想法吗?


解决方案

您可以使用regexp替换这些字符。

https://logging.apache.org/log4j/2.x/manual/layouts.html

%replace{%msg}{[ ]+}{}

这似乎是一个重复的问题:How to remove or replace newline from log messages log4j

另一方面,PatternLayout扩展了AbstractStringLayout,因此您可以创建"自定义PatternLayout"。

https://github.com/apache/logging-log4j2/blob/master/log4j-core/src/main/java/org/apache/logging/log4j/core/layout/PatternLayout.java

相关文章