您的位置:首页 > 运维架构 > Linux

Linux下用JMap对Java程序进行性能测试检查内存泄露问题

2012-11-22 00:35 716 查看
写了个Java程序,但总出现内存不足而退出,然后分析一下:



因为在Linux环境,用jdk自带的jmap工具(Linux/Unix环境特有的),可以对进程中的内存对象监视,然后就运行命令jmap -histo [pid],找内存中的对象数目变化。

程序运行一段时间之后,内存已经使用很大,jmap发现byte和int对象最多,程序中确实用了很多byte和int数组,然后手动设为null,但觉 着这种对象一般情况应该能自动回收才对,改完运行还是不行,再继续分析,发现Statement对象数目也比较多,感觉比较可疑,就找到数据库操作那块代 码,发现一个数据库连接不断的new Statement对象,没有close,加上close之后,问题解决了。

结论:数据库操作时从大到小是Connection,Statement,ResultSet对象,关闭了大的可以不关闭小的,但开着大的,就得关闭次大 的。如果用了连接池,连接的关闭是必须的,但是假断开连接,还必须关闭Statement或PreparedStatement等类型对象。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: