您的位置:首页 > 编程语言 > Java开发

诊断Java中的内存泄露

2015-12-04 10:06 288 查看
昨天给大家讲的JAVA内存结构,转发以下几个命令用来分析内存问题非常有用:

首先,我用下面的命令监视进程:

(如果有的话还有New Relic)

如果你看到内存上升很快,可能是因为虚拟机设置。如果你没有明确指定JVM的内存设置,它将设置默认值给他们。要获得默认值,使用以下命令:

如果这些都不符合你所希望的,那么你就需要指定JVM的内存设置。可以用下面的命令设置最小和最大堆大小:

尽管你有了合理的内存设置,也可以监控进程,但你仍然可能看到内存随时间增加。为了进一步探究原因,你可以使用下面的命令查看对象实例的直方图:

如果仍然没有足够的信息,那么可以用以下命令进行堆转储:

通常,我会用两个堆转储,然后使用下面的jhat命令比较它们:

这个命令会启动一个HTTP服务器,你可以用它来探索这两个堆转储之间的差值。在默认情况下,HTTP服务器启动7000端口,你可以在浏览器中访问该端口。

如果你有防火墙,可以通过SSH访问,那么你可以通过如下命令连接该端口:

向下滚动到第一页的底部,你会看到两个有用的链接:
Show heap histogram
Show
instance counts for all classes (excluding platform)

这将给你展示在不同堆转储之间所有“新”的实例,应该对你检测泄漏来自哪里有些帮助。截图如下:



然后你就拥有了一个神奇命令行的快速查看目录,以便于你需要诊断内存泄漏时使用(然而我总是忘记)。
原文链接: dzone 翻译: ImportNew.com fzr
译文链接: http://www.importnew.com/17153.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: