美文网首页java 内存分析
Jvm dump介绍与使用(内存与线程)

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

作者: Brave_Coder | 来源:发表于2018-02-01 15:20 被阅读229次

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

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

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

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

两个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

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

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

【线程dump】

jstack -m >jvm_deadlocks.txt

jstack -l >jvm_listlocks.txt

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

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

相关文章

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

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

  • 高效并发

    从JVM的角度看一下Java与线程,内存模型,线程安全以及JVM对于锁的优化 硬件内存模型与JVM内存模型 硬件的...

  • 每日一结——JVM内存模型

    JVM内存模型 JVM内存模型分为1.7与1.8版本(其中黄色代表线程共享,白色代表线程私有) 程序计数器 线程在...

  • java核心知识点,pdf文档,让你彻底告别重复的CRUD

    JVM 线程 JVM内存区域 JVM运行时内存 垃圾回收与算法 Java四种引用类型 GC 分代收集算法 VS 分...

  • JVM内存与线程

    Java内存模型 缓存一致性 计算机的存储设备与处理器之间的运算速度存在几个数量级的差距,所以,在处理器和内存...

  • Jvm dump jstack jmap jstat 介绍与使用

    总结: (1)栈信息:jstack 输出的信息。 (2)堆信息:jmap -dump 输出的文件, (3)js...

  • JVM Heap dump和Thread dump

    1、内存Heap Dump文件抓取 heap dump记录了JVM中堆内存运行的情况。 XX:+HeapDumpO...

  • Java基础之内存模型

    Java基础之内存模型 目录 Java内存模型简单介绍 JVM介绍 存储方式 并发原因 Java内存模型与系统内存...

  • 服务器JVM等查看

    常用 JVM性能调优监控工具JDK内置工具使用JAVA线程dump分析JVM致命错误日志1 . CPU的监控 cs...

  • Java知识图谱

    Java基础 JVM JVM内存模型和结构 GC原理&内存分配策略 性能调优:Thread Dump class ...

网友评论

    本文标题:Jvm dump介绍与使用(内存与线程)

    本文链接:https://www.haomeiwen.com/subject/mfvdzxtx.html