有没有办法用ibm-jdk for linux进行实时堆转储?

时间:2010-12-10 07:01:29

标签: java jdk1.6 jconsole jmap

我知道当在这个JVM上发生OutOfMemoryException时可以转储堆,但是可以用jmap或jconsole等工具询问实时转储吗?

4 个答案:

答案 0 :(得分:6)

你需要知道有“系统”转储(基本上是OS核心文件)和“堆”又名便携式堆转储(PHD)。后者不太有用,因为它们不包含实际数据。它们默认启用。

在AIX或Linux上通常,您将设置-Xdump:system-Xdump:system:events=gpf+user的缩写)以允许kill -3 <pid>触发堆转储。

顺便说一句,您可以使用默认选项使用kill -ABRT <pid>。但是,这将终止您的JVM。

运行java -Xdump:what以查看您的默认设置,例如:

> /usr/java6/bin/java -Xdump:what -version

Registered dump agents
----------------------
-Xdump:system:
    events=gpf+abort+traceassert,
    label=/home/u0002824/core.%Y%m%d.%H%M%S.%pid.%seq.dmp,
    range=1..0,
    priority=999,
    request=serial
----------------------
...
java version "1.6.0"
Java(TM) SE Runtime Environment (build pap3260sr9fp2-20110627_03(SR9 FP2))

打开系统转储:

> /usr/java6/bin/java -Xdump:system -Xdump:what -version

Registered dump agents
----------------------
-Xdump:system:
    events=gpf+user+abort+traceassert,
    label=/home/u0002824/core.%Y%m%d.%H%M%S.%pid.%seq.dmp,
    range=1..0,
    priority=999,
    request=serial
----------------------
-Xdump:heap:
    events=systhrow,
    filter=java/lang/OutOfMemoryError,
    label=/home/u0002824/heapdump.%Y%m%d.%H%M%S.%pid.%seq.phd,
    range=1..4,
    priority=500,
    request=exclusive+compact+prepwalk,
    opts=PHD
----------------------
-Xdump:java:
    events=gpf+user+abort+traceassert,
    label=/home/u0002824/javacore.%Y%m%d.%H%M%S.%pid.%seq.txt,
    range=1..0,
    priority=400,
    request=exclusive+preempt
----------------------
-Xdump:java:
    events=systhrow,
    filter=java/lang/OutOfMemoryError,
    label=/home/u0002824/javacore.%Y%m%d.%H%M%S.%pid.%seq.txt,
    range=1..4,
    priority=400,
    request=exclusive+preempt
----------------------
-Xdump:snap:
    events=gpf+abort+traceassert,
    label=/home/u0002824/Snap.%Y%m%d.%H%M%S.%pid.%seq.trc,
    range=1..0,
    priority=300,
    request=serial
----------------------
-Xdump:snap:
    events=systhrow,
    filter=java/lang/OutOfMemoryError,
    label=/home/u0002824/Snap.%Y%m%d.%H%M%S.%pid.%seq.trc,
    range=1..4,
    priority=300,
    request=serial
----------------------
...

不要忘记在核心 * .dmp 文件上运行jre/bin/jextract

答案 1 :(得分:4)

答案 2 :(得分:3)

好的,我终于回答了自己:应用程序有一个远程管理界面,所以我将实现一个调用com.ibm.jvm.Dump.HeapDump()方法的新命令。

答案 3 :(得分:0)

我认为有一个像JProfiler这样的工具。它将很好地与Eclipse一起工作