首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

错误日志没有堆栈信息

2012-08-13 
异常日志没有堆栈信息昨天财务出现一个问题,线上一直在报错:日志截屏如下:有异常,但是就只有一个java.lang

异常日志没有堆栈信息

昨天财务出现一个问题,线上一直在报错:日志截屏如下:错误日志没有堆栈信息

有异常,但是就只有一个java.lang.NullPointerException异常,这个没有堆栈信息,我怎么查问题呢?后来经过查询,这个问题其实是跟JDK5引入的一个新特性有关,对于一些频繁抛出的异常,JDK为了性能会做一个优化,在JIT重新编译后会抛出没有堆栈的异常。在使用server模式的时候,这个优化是开启的,我们的服务器跑在server模式下并且jdk版本是6,因此在频繁抛出java.lang.NullPointerException异常一定次数后优化开始起作用,只抛出没有堆栈的异常信息了。参考文档:http://java.sun.com/j2se/1.5.0/relnotes.html#hotspot

为了验证,我还简单写了一段代码验证下:运行结果:[fin@vm-crm-dev-144-100 longer]$ java TestLog
count is20708
为了能看到堆栈,可以重启服务器再观察,也可以看下以前老的日志。

但是大部分情况下,我们建议还是去掉此优化:通过启动参数中加入:
-XX:-OmitStackTraceInFastThrow


热点排行