如何记录格式化消息、对象数组、异常?

2022-02-21 00:00:00 logging exception java slf4j

记录异常的填充消息和堆栈跟踪的正确方法是什么?

logger.error(
    "
context info one two three: {} {} {}
",
    new Object[] {"1", "2", "3"},
    new Exception("something went wrong"));

我想生成类似以下内容的输出:

context info one two three: 1 2 3
java.lang.Exception: something went wrong
stacktrace 0
stacktrace 1
stacktrace ...

我的SLF4J版本是1.6.1。


解决方案

从SLF4J1.6.0开始,如果存在多个参数,并且日志记录语句中的最后一个参数是异常,则SLF4J将假定用户希望将最后一个参数视为异常,而不是简单的参数。另请参阅relevant FAQ entry。

因此,编写(SLF4J版本1.7.x和更高版本)

 logger.error("one two three: {} {} {}", "a", "b", 
              "c", new Exception("something went wrong"));

或编写(SLF4J版本1.6.x)

 logger.error("one two three: {} {} {}", new Object[] {"a", "b", 
              "c", new Exception("something went wrong")});

将产生

one two three: a b c
java.lang.Exception: something went wrong
    at Example.main(Example.java:13)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at ...
确切的输出将取决于底层框架(例如Logback、log4j等)以及底层框架的配置方式。但是,如果最后一个参数是异常,则无论基础框架如何,它都将被解释为异常。

相关文章