每次我怀疑有内存泄漏时,我都要翻箱倒柜找这些命令。所以,这里总结一下以备后用:
首先,我用下面的命令监视进程:
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 |
尽管你有了合理的内存设置,也可以监控进程,但你仍然可能看到内存随时间增加。为了进一步探究原因,你可以使用下面的命令查看对象实例的直方图:
1 | jmap -histo $PID |
如果仍然没有足够的信息,那么可以用以下命令进行堆转储:
1 | jmap -dump:format=b,file=/tmp/dump1.hprof $PID |
通常,我会用两个堆转储,然后使用下面的jhat命令比较它们:
1 | jhat -baseline /tmp/dump1.hprof /tmp/dump2.hprof |
这个命令会启动一个HTTP服务器,你可以用它来探索这两个堆转储之间的差值。在默认情况下,HTTP服务器启动7000端口,你可以在浏览器中访问该端口。
如果你有防火墙,可以通过SSH访问,那么你可以通过如下命令连接该端口:
1 | ssh -L 7000 :localhost: 7000 $HOST |
向下滚动到第一页的底部,你会看到两个有用的链接:
这将给你展示在不同堆转储之间所有“新”的实例,应该对你检测泄漏来自哪里有些帮助。截图如下:
然后你就拥有了一个神奇命令行的快速查看目录,以便于你需要诊断内存泄漏时使用(然而我总是忘记)。
前两天在一群里看见有人推荐一个app叫问啊,就可以发题答题那种的,感觉就跟uber滴滴打车似的,一般这种软件一上来就砸钱给红包啥的,哥之前刷过uber的单有经验!试验了几次应该可以刷,把注册红包和之前领的红包钱套现,目前我提了五十多,目测还能刷更多。ps,但是尽量要问技术相关的问题,不然容易被封。
有技术的可以自己试,不会的可以q我315414695:QQ群290551701 聚集很多互联网精英,技术总监,架构师,项目经理!开源技术研究,欢迎业内人士,大牛及新手有志于从事IT行业人员进入!
- 1楼五月的仓颉
- 内存泄露一般使用,,jstat -gcutil pid 观察一下P也就是永久代的占比就能发现,,在无法直接定位出内存中是哪块对象占用的内存太大,无法释放导致的内存泄露,就要使用jmap -dump打出内存转储快照了