ChatGPT解决这个技术问题 Extra ChatGPT

Java Logging 框架中的标记是什么,使用它们的原因是什么?

我第一次听说标记是在阅读时:

http://slf4j.org/faq.html

我检查了 Logger 对象的可用方法:

http://www.slf4j.org/api/org/slf4j/Logger.html

http://logging.apache.org/log4j/2.x/log4j-api/apidocs/org/apache/logging/log4j/Logger.html

并找到接口:

http://www.slf4j.org/api/org/slf4j/Marker.html

http://logging.apache.org/log4j/2.x/log4j-api/apidocs/org/apache/logging/log4j/Marker.html

我从中获得的更深入的信息:

http://logback.qos.ch/manual/filters.html

但我仍然很困惑......请注意,我问的是为什么,而不是如何使用它们,所以这不是重复的:

在 SLF4J/Logback 中使用标记的最佳实践

更新似乎当您使用标记时,您还需要编写自定义 Java 代码,而不是在 XML 或 .property 文件中进行配置......

更新 2 来自 http://logback.qos.ch/manual/appenders.html#OnMarkerEvaluator

Marker notifyAdmin = MarkerFactory.getMarker("NOTIFY_ADMIN");
logger.error(notifyAdmin,
  "This is a serious an error requiring the admin's attention",
   new Exception("Just testing"));
要使用标记,您需要使用 SLF4J 提供的标记 API。这就是“自定义Java代码”的意思吗?
@Ceki 似乎只使用 Logger.warn(Marker, msg) 并没有给您带来任何好处,直到您为过滤器编写自定义类并注册它们...... logback.xml 的普通语法没有使用 Marker 的特殊能力(只是通过 %marker 打印它们)
logback.qos.ch/manual/appenders.html#OnMarkerEvaluator 中呈现的内容中发现什么“特别”?
@Ceki 谢谢你的意见!是不是只有一处可以使用记号笔?
@Ceki 现在我们正在使用 Elasticsearch,它是标记特殊事件的方法。我们将预定义的标记保存在一个专门的类中以供重用。当您仅在文本日志上使用 grep 时,这并不明显。

C
Ceki

这是问题“Best practices for using Markers in SLF4J/Logback”的重新散列版本 my answer

标记可用于为单个日志语句着色或标记。您如何处理这些颜色(即标记)完全取决于您。然而,两种模式似乎对于标记的使用很常见。

触发:可以指示某些附加程序在存在某个标记的情况下执行操作。例如,可以将 SMTPAppender 配置为在日志事件被标记为 NOTIFY_ADMIN 标记时发送电子邮件,而不管日志级别如何。请参阅 logback 文档中的基于标记的触发。您还可以组合日志级别和标记以进行触发。过滤:标记对于使某些有价值的日志语句脱颖而出非常有用。例如,您可以使用颜色“DB”对所有与持久性相关的日志(在各种和多个类文件中)进行着色/标记。然后,您可以过滤“DB”:禁用日志记录,但标有 DB 的日志语句除外。有关更多信息,请参阅 logback 文档中有关过滤器的章节(搜索 MarkerFilter)。请注意,标记过滤不仅可以通过 logback 执行,还可以通过日志分析工具执行。

在标记出现之前,为了实现类似的行为,您可以选择 1) 使用自定义级别 2) 使用修改后的记录器名称。 SLF4J API 当前不支持自定义级别。至于选项 2,如果需要修改一个或两个记录器,则为记录器名称添加后缀(或前缀)是可行的。一旦需要对 3 个或更多记录器进行“子分类”,该方法就变得不切实际,因为相关的配置文件变得无法管理。

尽管单个标记可能已经非常有用,但 SLF4J 的下一个版本,即 2.0 版,将允许每个日志语句有多个标记。


也可以在 SiftingAppender 中用于鉴别器 stackoverflow.com/a/30552012/1012497