Jvm dump介绍与使用(内存与线程)
来源:互联网 发布:淘宝流量是什么意思啊 编辑:程序博客网 时间:2024/06/03 15:22
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文件中搜索相关信息
- Jvm dump介绍与使用(内存与线程)
- Jvm dump介绍与使用
- Dump文件介绍与使用
- (一)线程------JVM体系结构与内存模型概要
- JVM读书笔记(六):Java内存模型与线程
- jvm(12)-java内存模型与线程
- jvm 内存模型与线程 & Volatile
- JVM初窥:Java内存模型与线程
- JVM内存介绍与参数配置
- Java JVM内存介绍与配置
- 使用jmap dump 分析JVM内存状态
- AssertValid与Dump的介绍
- jvm 内存dump、gc查看、线程死锁,jmap、jstack、jstat
- jvm 内存dump、gc查看、线程死锁,jmap、jstack、jstat
- JProfiler的详细使用介绍(JVM对象内存线程监测工具)
- JProfiler的详细使用介绍(JVM对象内存线程监测工具)
- dump JVM 内存
- C#线程与线程池使用介绍
- [转载]easyui datagrid 行内编辑功能
- jquery easyui 布局与动态打开窗口tabs
- StringBuffer的用法
- Ubuntu16.04 apache2 配置相关知识点
- 可见性与生存期
- Jvm dump介绍与使用(内存与线程)
- Numpy.argsort()(Python)
- 数据结构-二维数组-对称矩阵压缩存储
- Spring 的 init-method 和 destory-method
- 最长公共子串
- python3.6中安装xgboost 基于win7 64位系统
- Activity
- 快速排序
- sparkstreaming