记录填充消息和异常堆栈跟踪的正确方法是什么?
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 版本是 1.6.1。
原文由 rowe 发布,翻译遵循 CC BY-SA 4.0 许可协议
从 SLF4J 1.6.0 开始,在存在多个参数的情况下,如果日志语句中的最后一个参数是异常,则 SLF4J 将假定用户希望将最后一个参数视为异常而不是简单参数。另请参阅 相关的 FAQ 条目。
因此,编写(在 SLF4J 1.7.x 及更高版本中)
或写作(在 SLF4J 版本 1.6.x 中)
会产生
确切的输出将取决于底层框架(例如 logback、log4j 等)以及底层框架的配置方式。但是,如果最后一个参数是异常,则无论底层框架如何,它都将被解释为异常。