java - Jmap 无法连接进行转储

标签 java jvm heap-memory

我们有一个应用程序的公开测试版,它偶尔会导致堆空间溢出。 JVM 的 react 是永久休假。

为了分析这一点,我想看看内存失败的地方。 Java 不希望我这样做。该进程仍在内存中,但似乎没有被识别为 java 进程。

有问题的服务器是 debian Lenny 服务器,Java 6u14

/opt/jdk/bin# ./jmap -F -dump:format=b,file=/tmp/apidump.hprof 11175
Attaching to process ID 11175, please wait...
sun.jvm.hotspot.debugger.NoSuchSymbolException: Could not find symbol "gHotSpotVMTypeEntryTypeNameOffset" in any of the known library names (libjvm.so, libjvm_g.so, gamma_g)
at sun.jvm.hotspot.HotSpotTypeDataBase.lookupInProcess(HotSpotTypeDataBase.java:390)
at sun.jvm.hotspot.HotSpotTypeDataBase.getLongValueFromProcess(HotSpotTypeDataBase.java:371)
at sun.jvm.hotspot.HotSpotTypeDataBase.readVMTypes(HotSpotTypeDataBase.java:102)
at sun.jvm.hotspot.HotSpotTypeDataBase.<init>(HotSpotTypeDataBase.java:85)
at sun.jvm.hotspot.bugspot.BugSpotAgent.setupVM(BugSpotAgent.java:568)
at sun.jvm.hotspot.bugspot.BugSpotAgent.go(BugSpotAgent.java:494)
at sun.jvm.hotspot.bugspot.BugSpotAgent.attach(BugSpotAgent.java:332)
at sun.jvm.hotspot.tools.Tool.start(Tool.java:163)
at sun.jvm.hotspot.tools.HeapDumper.main(HeapDumper.java:77)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at sun.tools.jmap.JMap.runTool(JMap.java:179)
at sun.tools.jmap.JMap.main(JMap.java:110)
Debugger attached successfully.
sun.jvm.hotspot.tools.HeapDumper requires a java VM process/core!

最佳答案

解决方案非常简单。我以 root 身份运行 jmap,但我必须以启动 jvm 的用户身份运行它。我现在要羞愧地把头藏起来。

关于java - Jmap 无法连接进行转储,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2913948/

相关文章:

java - 从远程位置动态加载 jar

java - JVM如何访问文件系统

c++ - C++ 中的堆错误

garbage-collection - 尽管有足够的 PermSize 和 OldGen 空间,JVM 是否仍会遇到 “java.lang.OutOfMemoryError:"

c - 返回 c 中的连续 block

c++ - 当相关的构造函数是私有(private)的时,如何在堆上返回一个类实例?

java - 每当执行应用程序时,它在 android 模拟器中显示为空白

java - Hibernate + MySQL - 如何获得不可猜测的生成 ID?

java - FileOutputStream 部分不起作用

java - JVM、字节码、垃圾收集器和计算机代码解释(使用多次返回 "new Object()"的函数)