jmap崩溃并显示“无法获取类数据”的错误信息。

9

我遇到了Java核心转储问题;使用以下命令运行jmap:

/usr/java/jdk1.8.0_25/bin/jmap -dump:format=b,file=dump.hprof  /usr/bin/java core.31497 

给出以下异常:
Attaching to core core.31497 from executable /usr/bin/java, please wait...
...
JVM version is 25.25-b02
...
Exception in thread "main" java.lang.reflect.InvocationTargetException
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at sun.tools.jmap.JMap.runTool(JMap.java:201)
    at sun.tools.jmap.JMap.main(JMap.java:130)
Caused by: sun.jvm.hotspot.utilities.AssertionFailure: can not get class data for         sun/nio/ch/ThreadPool$$Lambda$10x00000007c0214428
    at sun.jvm.hotspot.utilities.Assert.that(Assert.java:32)
    at sun.jvm.hotspot.utilities.HeapHprofBinWriter.writeInstance(HeapHprofBinWriter.java:803)
    ...
    at sun.jvm.hotspot.tools.Tool.start(Tool.java:223)
    at sun.jvm.hotspot.tools.Tool.execute(Tool.java:118)
    at sun.jvm.hotspot.tools.HeapDumper.main(HeapDumper.java:83)

有什么想法吗?

由于Lambda表达式是从Java 8开始引入的,这可能是Java 7/8的问题吗?/usr/bin/java是否指向Java 7分发版? - Magnilex
我也曾经这样想过。我明确使用的是JDK8的一个版本:/some/path/to/software/jdk8/jmap,认为可能是因为我的$PATH中有JDK7的java导致了这个问题。但是我把所有旧版本的java都从路径中移除了,仍然遇到了Gregory报告的同样的错误。 - perpetual_check
7
发现了这个。看起来相关:https://bugs.openjdk.java.net/browse/JDK-8044416 - perpetual_check
@Magnilex:不,这个Java是8版的。 - Gregory Golberg
1个回答

3

正如@sethwm所提到的,这是一个已知的 bug。

从 Java 8 Update 60 开始,该问题已得到修复。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接