诊断Java中的内存泄露

每次我怀疑有内存泄漏时,我都要翻箱倒柜找这些命令。所以,这里总结一下以备后用:
  首先,我用下面的命令监视进程:
  while ( sleep 1 ) ; do ps -p $PID -o %cpu,%mem,rss  ; done
  (如果有的话还有New Relic)
  如果你看到内存上升很快,可能是因为虚拟机设置。如果你没有明确指定JVM的内存设置,它将设置默认值给他们。要获得默认值,使用以下命令:
  java -XX:+PrintFlagsFinal -version | grep -i HeapSize
  如果这些都不符合你所希望的,那么你需要指定JVM的内存设置。可以用下面的命令设置小和大堆大小:
  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
  向下滚动到第一页的底部,你会看到两个有用的链接:
  Show heap histogram
  Show instance counts for all classes (excluding platform)
  这将给你展示在不同堆转储之间所有“新”的实例,应该对你检测泄漏来自哪里有些帮助。截图如下:

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

其实做为一个开发者,有一个学习的氛围跟一个交流圈子特别重要这里我推荐一个Java交流群664389243,不管你是小白还是大牛欢迎入驻,大家一起交流成长。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值