我第一次听说标记是在阅读时:
我检查了 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"));
grep
时,这并不明显。
这是问题“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 版,将允许每个日志语句有多个标记。