[开发、应用中老是会遇到OutOfMemory异常,而且常常是过一段时间内存才被吃光,这里可以利用java heap dump出jvm内存镜像,然后再对其进行分析来查找问题。《java heap dum

jhat 是Java堆分析工具(Java heap Analyzes Tool). 在JDK6u7之后成为标配. 使用该命令需要有一定的Java开发经验,官方不对此工具提供技术支持和客户服务。

用法:

jhat [ options ] heap-dump-file

参数:

options 可选命令行参数,请参考下面的 Options

heap-dump-file 要查看的二进制Java堆转储文件(Java binary heap dump file)。 如果某个转储文件中包含了多份 heap dumps, 可在文件名之后加上 # 的方式指定解析哪一个 dump, 如: myfile.hprof#3

示例

jmap转储可以使用如下方式:

jmap -dump:file=DumpFileName.txt,format=b pid

例如:

C:\Users\Administrator\Desktop>jmap -dump:file=D:/javaDump.hprof,format=b 3614

Dumping heap to D:\javaDump.hprof ...

Heap dump file created

其中, 3614 是此次启动Tomcat后,通过tasklist,或任务管理器查看到的 java进程的ID,一般来说, jmap 需要和 java的版本一致或者兼容,才能成功导出. 如果不知道如何使用,直接输入 jmap, 或者 jmap -h 则可以看到提示信息.

然后分析时使用jhat命令,如下所示:

jhat -J-Xmx1024m D:/javaDump.hprof

...... 一堆信息 ...

Snapshot resolved.

Started HTTP server on port 7000

Server is ready.

而 jhat 的 -J 参数是因为默认JVM的堆内存可能不足以加载整个dump 文件. 根据需要进行调整. 根据提示知道端口号是 7000,

详细说明

jhat 命令解析Java堆转储文件,并启动一个 web server. 然后用浏览器来查看/浏览 dump 出来的 heap. jhat 命令支持预先设计的查询, 比如显示某个类的所有实例. 还支持 对象查询语言(OQL, Object Query Language)。 OQL有点类似SQL,专门用来查询堆转储。 OQL相关的帮助信息可以在 jhat 命令所提供的服务器页面最底部. 如果使用默认端口, 则OQL帮助信息页面为: http://localhost:7000/oqlhelp/

Java生成堆转储的方式有多种:

使用 jmap -dump 选项可以在JVM运行时获取 heap dump. (可以参考上面的示例)详情参见: jmap(1)

在虚拟机启动时如果指定了 -XX:+HeapDumpOnOutOfMemoryError 选项, 则抛出 OutOfMemoryError 时, 会自动执行堆转储。

[通过上一篇博客linux/windows下利用JDK自带的工具获取thread dump文件和heap dump文件,我们知道如何获取到java应用程序的heap dump文件。现在我们使用一些图形化工具,来

Options

-stack false|true

关闭对象分配调用栈跟踪(tracking object allocation call stack)。 如果分配位置信息在堆转储中不可用. 则必须将此标志设置为 false. 默认值为 true.

-refs false|true

关闭对象引用跟踪(tracking of references to objects)。 默认值为 true. 默认情况下, 返回的指针是指向其他特定对象的对象,如反向链接或输入引用(referrers or incoming references), 会统计/计算堆中的所有对象。

-port port-number

设置 jhat HTTP server 的端口号. 默认值 7000.

-exclude exclude-file

指定对象查询时需要排除的数据成员列表文件(a file that lists data members that should be excluded from the reachable objects query)。 例如, 如果文件列列出了 java.lang.String.value , 那么当从某个特定对象 Object o 计算可达的对象列表时, 引用路径涉及 java.lang.String.value 的都会被排除。

-baseline exclude-file

指定一个基准堆转储(baseline heap dump)。 在两个 heap dumps 中有相同 object ID 的对象会被标记为不是新的(marked as not being new). 其他对象被标记为新的(new). 在比较两个不同的堆转储时很有用.

-debug int

设置 debug 级别. 0 表示不输出调试信息。 值越大则表示输出更详细的 debug 信息.

-version

启动后只显示版本信息就退出

-h

显示帮助信息并退出. 同 -help

-help

显示帮助信息并退出. 同 -h

-J< flag >

因为 jhat 命令实际上会启动一个JVM来执行, 通过 -J 可以在启动JVM时传入一些启动参数. 例如, -J-Xmx512m 则指定运行 jhat 的Java虚拟机使用的最大堆内存为 512 MB. 如果需要使用多个JVM启动参数,则传入多个 -Jxxxxxx.

另请参阅:

原文日期: 2014-05-04

翻译日期: 2014-11-21

翻译人员: 铁锚

[为了查red5-0.7.0的内存泄露问题,由于dump文件太大,用JDK自带的工具JHat,加载不进来,Jhat比较垃圾,用到了两个工具:   1.IBM Memory Analyzer 1)下载地址: h

java heap分析工具_Java Heap dump文件分析工具jhat简介相关推荐

  1. java内存分析工具_java内存查看与分析

    业界有很多强大的java profile的工具,比如Jporfiler,yourkit,这些收费的东西我就不想说了,想说的是,其实java自己就提供了很多内存监控的小工具,下面列举的工具只是一小部分, ...

  2. java 分析内存_Java 内存查看与分析

    1:gc日志输出 在jvm启动参数中加入 -XX:+PrintGC -XX:+PrintGCDetails -XX:+PrintGCTimestamps -XX:+PrintGCApplication ...

  3. jstat 内存泄漏_基于Java内存dump文件分析解决内存泄漏问题

    概述 本文介绍一次解决现场java内存泄漏问题的经过,希望能提供后续遇到类似情况的读者一点思路. 生产环境发现的问题问题 生产环境运维人员反馈,服务器(windows系统)卡死,相关的服务都运行异常, ...

  4. Java的dump文件分析及JProfiler使用

    Java的dump文件分析及JProfiler使用 1 dump文件介绍 从软件开发的角度上,dump文件就是当程序产生异常时,用来记录当时的程序状态信息(例如堆栈的状态),用于程序开发定位问题. i ...

  5. JVM之VisualVM安装使用以及dump文件分析

    一.简介 VisualVM 是一款免费的\集成了多个JDK 命令行工具的可视化工具,它能为您提供强大的分析能力,对 Java 应用程序做性能分析和调优.这些功能包括生成和分析海量数据.跟踪内存泄漏.监 ...

  6. java dumpstack_Java获取执行进程的dump文件及获取Java stack

    转发自https://blog.csdn.net/MCC_MCC_MCC/article/details/80623156 1.Windows/Linux环境下查看Java进程ID方法 使用Java自 ...

  7. Windbg内核调试之四: Dump文件分析

    Dump 文件分析很大程度上就是分析蓝屏产生的原因.这种系统级的错误算是Windows提示错误中比较严重的一种(更严重的还有启动黑屏等硬件或软件兼容性错误等等).说它是比较严重,是因为毕竟Window ...

  8. Java Heap dump文件分析工具jhat简介

    jhat 是Java堆分析工具(Java heap Analyzes Tool). 在JDK6u7之后成为标配. 使用该命令需要有一定的Java开发经验,官方不对此工具提供技术支持和客户服务. 用法: ...

  9. java dump 工具_Java线程Dump分析工具--jstack

    jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项"-J-d64",Windows的jstack使 ...

最新文章

  1. NAS存储对称和非对称结构之前的区别概述
  2. pandas 读取写入保存文件
  3. 并发编程之 Java 内存模型 + volatile 关键字 + Happen-Before 规则
  4. Abbreviation
  5. 语言中2000u等于多少_PLC文本语言
  6. php验证mysql内数据_MySQL中数据类型的验证_MySQL
  7. Node.js 连接 MySQL 并进行数据库操作
  8. 新机发布会用鸿蒙吗,鸿蒙操作系统及华为全场景新品发布会即将到来,硬件生态发展有望迎来加速度...
  9. 电脑亮度多少对眼睛好_黄江办公文员学费大概是多少,黄江附近哪个电脑学校比较好一点...
  10. 抓取Js动态生成数据且以滚动页面方式分页的网页
  11. linux 修改git端口号,SSH默认端口更改后使用Git
  12. 骁龙660_骁龙660卖到4000元!这款手机哪里来的自信?
  13. X 1 BT5kali
  14. 看完这篇“史密斯圆图”告别懵逼射频!
  15. UI中经常出现的下拉框下拉自动筛选效果的实现
  16. 实现cron时间表达式生成器
  17. 遇到电脑中病毒了怎么办
  18. linux多个网卡丢包,linux系统双网卡绑定及丢包问题
  19. 生成密钥、配送密钥和更新密钥
  20. 密码学与网络安全课程习题集及参考答案(一些思考题)

热门文章

  1. Android之ListView(三)
  2. 数据离散程度的衡量指标
  3. Executors类创建四种常见线程池
  4. 【WMWare 克隆CentOS虚拟机 】解决克隆后 ip 冲突 主机名重复问题
  5. 为什么 LED 灯会在相机上出现频闪?揭秘
  6. CloudStack+XenServer详细部署方案 交换机配置和服务器连线
  7. cloudstack 术语
  8. 2022强网杯线上赛 qmachine
  9. 金九银十已到,大厂面试大全+面试经历都在这了(建议收藏)
  10. System.Runtime.InteropServices.COMException:“服务器出现意外情况。 (异常来自