Java Logging 框架中的标记是啥,使用它们的原因是啥?
Posted
技术标签:
【中文标题】Java Logging 框架中的标记是啥,使用它们的原因是啥?【英文标题】:What are markers in Java Logging frameworks and what is a reason to use them?Java Logging 框架中的标记是什么,使用它们的原因是什么? 【发布时间】:2013-05-24 15:54:31 【问题描述】:我第一次听说标记是在阅读时:
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但我仍然感到困惑...请注意,我问的是 为什么,而不是 如何 使用它们,所以这不是以下内容的重复:
Best practices for using Markers in SLF4J/LogbackUPDATE 似乎当您使用标记时,您还需要编写自定义 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
时,这一点并不明显。
【参考方案1】:
这是问题“Best practices for using Markers in SLF4J/Logback”的重新散列版本my answer。
标记可用于着色或标记单个日志语句。你用这些颜色做什么,即标记,完全取决于你。但是,标记的使用似乎有两种常见的模式。
触发:可以指示某些附加程序在存在特定标记的情况下执行操作。例如,SMTPAppender
可以配置为在日志事件被标记为NOTIFY_ADMIN
标记时发送电子邮件,无论日志级别如何。请参阅 logback 文档中的 marker-based triggering。您还可以结合日志级别和标记进行触发。
过滤:标记对于使某些有价值的日志语句脱颖而出非常有用。例如,您可以用颜色“DB”为所有与持久性相关的日志(在各种和多个类文件中)着色/标记。然后,您可以过滤“DB”:禁用日志记录,但标有 DB 的日志语句除外。请参阅 logback 文档中的 chapter on filters 了解更多信息(搜索 MarkerFilter)。请注意,标记过滤不仅可以通过 logback 执行,还可以通过日志分析工具执行。
在标记出现之前,为了实现类似的行为,您可以选择 1) 使用自定义级别 2) 使用修改后的记录器名称。 SLF4J API 当前不支持自定义级别。至于选项 2,如果需要修改一个或两个记录器,则为记录器名称添加后缀(或前缀)是可行的。一旦需要对 3 个或更多记录器进行“子分类”,这种方法就变得不切实际,因为相关的配置文件变得难以管理。
尽管单个标记可能已经非常有用,但 SLF4J 的下一个版本,即 2.0 版,将允许每个日志语句使用多个标记。
【讨论】:
也可以用在SiftingAppender作为鉴别器***.com/a/30552012/1012497以上是关于Java Logging 框架中的标记是啥,使用它们的原因是啥?的主要内容,如果未能解决你的问题,请参考以下文章