如何诊断 Java 中的内存泄露

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

每次我怀疑有内存泄漏时,我都要翻箱倒柜找这些命令。所以,这里总结一下以备后用:

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

  1. while ( sleep 1 ) ; do ps -p $PID -o %cpu,%mem,rss  ; done 

(如果有的话还有New Relic)

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

  1. java -XX:+PrintFlagsFinal -version | grep -i HeapSize 

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

  1. java -Xms128m -Xmx256m 

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

jmap -histo $PID

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

jmap -dump:format=b,file=/tmp/dump1.hprof $PID

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

jhat -baseline /tmp/dump1.hprof /tmp/dump2.hprof

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

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

ssh -L 7000:localhost:7000 $HOST

向下滚动到***页的底部,你会看到两个有用的链接:

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

诊断Java中的内存泄露

然后你就拥有了一个神奇命令行的快速查看目录,以便于你需要诊断内存泄漏时使用(然而我总是忘记)。

责任编辑:王雪燕 来源: ImportNew
相关推荐

2010-10-25 10:10:27

ibmdwJava

2017-12-11 11:00:27

内存泄露判断

2014-12-18 10:16:00

Java

2010-11-05 13:02:58

内存iPhone

2017-10-26 08:43:18

JavaScript内存处理

2015-05-14 15:38:40

javajava内存泄露

2011-11-17 13:59:41

Java内存管理内存泄露

2015-01-14 13:50:58

AndroidHandler内存泄露

2009-06-16 11:11:07

Java内存管理Java内存泄漏

2010-09-25 11:32:24

Java内存泄漏

2010-09-25 11:23:15

Java内存泄露

2012-02-22 21:28:58

内存泄漏

2020-06-23 09:48:09

Python开发内存

2015-03-27 11:34:59

JavaJava编写引发内存泄露

2016-05-25 10:03:51

JavaScript内存泄露

2013-12-23 09:25:21

2021-03-22 16:55:14

Java程序员内存

2022-08-26 07:33:49

内存JVMEntry

2013-08-07 10:07:07

Handler内存泄露

2023-03-03 12:37:50

JavaJVM内存溢出
点赞
收藏

51CTO技术栈公众号