美文网首页FAQ
log4j 不打印异常堆栈

log4j 不打印异常堆栈

作者: liaijuyyer | 来源:发表于2021-11-06 12:32 被阅读0次

问题
最近在线上系统的错误日志中发现了一个现象 : 代码里用log4j打印系统运行时异常堆栈信息,在错误日志中无法看到堆栈信息,只有异常信息。后来发现这个是jdk的一个优化。JVM 为了性能会做优化,如果频繁的抛出某个异常,会重新编译,不再打印异常堆栈。

解决方案
解决这个问题也比较简单,如果不想每次都去查前面的 log 去看堆栈,只要在启动参数加上 -XX:-OmitStackTraceInFastThrow,就可以禁用该优化,强制打印异常堆栈。这样可能会导致,log 文件过大,不过产线上今天之前的 log 文件都会被压缩,所以感觉问题也不大。

相关文章

网友评论

    本文标题:log4j 不打印异常堆栈

    本文链接:https://www.haomeiwen.com/subject/prhjzltx.html