jmap "

2014-11-12 24 views
8

için bir sınıf verisi alamadı" ile bir Java çekirdek dökümü vardı; ile çalışan JMAP:jmap "

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) 

Herhangi düşünceler:

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

şu istisna verir?

+0

yana Java 8 Update ile başlayan giderildi? Java 7 dağıtımına işaret eden/usr/bin/java mı? – Magnilex

+0

Ben de öyle düşünmüştüm. JDK8'in bir sürümünü açık bir şekilde kullanıyordum:/some/path/to/software/jdk8/jmap ve belki de JDK7'nin java'mın $ PATH'mda olması nedeniyle sorun yarattığını düşündüm. Ama tüm eski java versiyonlarını yolumdan çıkardım ve yine de Gregory'nin bildirdiği aynı hatayı yaşadım. – sethwm

+7

Bunu keşfetti. İlgili görünüyor: https://bugs.openjdk.java.net/browse/JDK-8044416 – sethwm

cevap

3

@sethwm bu bahsedildiği gibi bilinen bir hatadır.

Bu bir Java7/8 sorun olabilir, lambda Java 8'den yeni 60.