• Jvm dump介绍与使用(内存与线程)


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

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

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

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

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

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

    使用top查看目前正在运行的进程使用系统资源情况。

    其中进程号为24660的进程,jps输出列表和top列表中都出现,并且在top列表中显示是由java COMMAND启动的。

    其中%MEM为2.9,说明占用系统内存为2.9%,当前系统大概8G内存;另外%CPU指的是当前进程使用CPU资源百分比;

    【内存dump】

    jmap –dump:live,format=b,file=heap.bin <pid>

    参考资料:http://docs.oracle.com/javase/6/docs/technotes/tools/share/jmap.html

    将生成的heap.bin文件,使用ha456.jar工具打开分析。java -jar -Xmx3000m ha456.jar

    【线程dump】

    jstack -m <pid> >jvm_deadlocks.txt

    jstack -l <pid> >jvm_listlocks.txt

    参考资料http://docs.oracle.com/javase/6/docs/technotes/tools/share/jstack.html

    使用top -H -p <pid>找出某进程中要分析的线程ID,然后将线程ID转换为16进制后,在线程dump文件中搜索相关信息

  • 相关阅读:
    关于开发BugRaid的想法(2)
    杭州.net俱乐部第一次见面会情况
    关于Bug管理的过程
    关于开发BugRaid的想法(1)
    变态的VS2005 SP1
    vs2003 sp1 download url
    proxy software
    敏捷开发
    Enterprise Library文档
    ETL
  • 原文地址:https://www.cnblogs.com/orionhp/p/6362718.html
Copyright © 2020-2023  润新知