2014-11-12 6 views
8

Aveva un core dump Java; jmap esecuzione con:jmap si blocca con "impossibile ottenere i dati della classe per"

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

ha pronunciato la seguente eccezione:

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) 

Qualche idea?

+0

Dal lambda è nuovo da Java 8, potrebbe essere un problema di Java7/8?/Usr/bin/java punta a una distribuzione Java 7? – Magnilex

+0

Anche io ci avevo pensato. Stavo usando esplicitamente una versione di JDK8:/some/path/to/software/jdk8/jmap e pensavo che forse perché JDK7 era java nel mio $ PATH che stava causando il problema. Ma ho rimosso tutte le vecchie versioni di java dal mio percorso e provo lo stesso bug segnalato da Gregory. – sethwm

+7

Scoperto di questo. Sembra rilevante: https://bugs.openjdk.java.net/browse/JDK-8044416 – sethwm

risposta

3

Come @sethwm ha menzionato questo è un bug noto.

E 'stato fissato iniziando con Java 8 Update 60.

Problemi correlati