内存dump与线程dump


很多情况下,都会出现dump这个字眼,java虚拟机jvm中也不例外,其中主要包括内存dump、线程dump。

当发现应用内存溢出或长时间使用内存很高的情况下,通过内存dump进行分析可找到原因。

当发现cpu使用率很高时,通过线程dump定位具体哪个线程在做哪个工作占用了过多的资源。

首先,内存dump是指通过jmap -dump <pid>输出的文件,而线程dump是指通过jstack <pid>输出的信息。

两个dump可以单独使用,也可以在特定场合下结合使用。

在linux操作系统下(已安装jdk),执行jps命令,列出正在运行的java程序的进程ID。

ps aux|grep java|sort -k4,4nr|head -n3 可查看 tomcat前三占用内存

jmap -dump:live,file=wx.dump <pid>  可以下载内存 dump  只dump存活的

jmap -dump:format=b,file=wx.dump <pid>   使用hprof二进制形式,输出jvm的heap内容到文件用jmap把进程内存使用情况dump到文件中

【线程dump】

jstack -m <pid> >jvm_deadlocks.txt

jstack -l <pid> >jvm_listlocks.txt

-l long listings,会打印出额外的锁信息,在发生死锁时可以用jstack -l pid来观察锁持有情况
-m mixed mode,不仅会输出Java堆栈信息,还会输出C/C++堆栈信息(比如Native方法)

ps -Lfp <pid>    或top -Hp <pid> 可以查看耗时最长的线程

 

可参考http://www.open-open.com/lib/view/open1390916852007.html


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM