Java Heap Dump

JavaHeapDump(2010-08-19 11:18:59)

<!-- 正文开始 -->

Java Heap Dump 是什么?
我们知道Java Heap 是所有类实例和数组对象分配的一个运行时数据区,其间所有Java VM线程在执行期间共享Heap 中的数据。那么一个Java heap dump相当于在一个特殊的时间点上生成的一个快照,它就像给一个繁忙的数据仓库在给定的时间上来了一个照片,我们通过这张快照可以识别哪些组件在那快照的那时间点上是可用的。

由于Java 说明文档并没有提及到Java heap dump,在各个不同的JVM厂商,存在各个对Java heap dump的介绍。 如IBM JVM的Java heap dump 提供的信息大至和Java Heap差不多。
Sun公司提供的信息基本上是JVM Stack,运行时常量池和Java Heap等.

如何生成Java Heap Dumps ?
Java Heap Dumps通常是由JVM自动生成,不过您也可以强制生成Java Heap Dumps。在大多数IBM的JVM上。Java Heap Dumps 在当Java Heap 用完前自动生成。在大多数Sun 公司的JVM上,你需要在JVM上配置以生成Java Heap dumps. 如果你想在java.lang.OutOfMemory出现时生成,你需要在某些Sun的发行版的JVM配置 –XX:+HeapDumpOnOutOfMemoryError 参数选项. 你同样需要配置 –agentlib:phrof=heap=dump选项来使用HPROF。如果JVM提供, 你可以使用jmap工具, 比如:jmap –dump 1234 将从进程号1234上生成Java heap dump. 你可以通过调用HotSpotDiagnostic MBean和dumpHeap 来利用JConsole来监视内存。
如果你想在IBM的JVMs上给JVM崩溃或是用户信号生成Java heap dumps, 你可以配置环境变量 IBM_HEAPDUMP和IBM_HEAP_DUMP置为TRUE. 如:可以在给IBM JVM发送一个SIGQUIT信号

具体请参阅你的JVM说明文档以获得更多信息,因为由于平台与厂商的不同,选项会有所变化。

在哪可以找到Java Heap Dumps ?
您可以在JVM进程的当前工作目录下找到Java heap dumps,除非你指定了另外的目录位置。
您可以在IBM JVMs上通过环境变量指定目录位置: IBM_HEAPDUMPDIR 和 _CEE_DEPTARG.
如果没有足够的空间给指定的目录,或JVM在指定目录下未获取写权限, Java Heap dumps 将会在操作系统的临时目录下生成。关于操作系统的默认临时目录位置和配置信息,请参阅你的操作系统手册。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值