本文正在参加「Java主题月 - Java Debug笔记活动」,详情查看 活动链接
slf4j:如何log格式化消息,对象数组,异常
log填充消息和异常堆栈跟踪的正确方法是什么?
logger.error(
"\ncontext info one two three: {} {} {}\n",
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 version 1.6.1
回答
从SLF4J 1.6.0开始,在存在多个参数的情况下,如果日志语句中的最后一个参数是一个异常,那么SLF4J将假定用户希望将最后一个参数视为一个异常,而不是一个简单的参数。请参见相关的FAQ项。
这样写(在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等)以及底层框架是如何配置的。但是,如果最后一个参数是一个异常,则无论底层框架如何,都会将其解释为异常。
回答二
除了@Ceki的回答之外,如果你正在使用logback并在项目中设置了配置文件(通常是logback.xml),你也可以定义日志来输出堆栈跟踪
<encoder>
<pattern>%date |%-5level| [%thread] [%file:%line] - %msg%n%ex{full}</pattern>
</encoder>
模式中的%ex是造成差别的原因
文章翻译自Stack Overflow:stackoverflow.com/questions/6…