English 中文(简体)
Location of Java dump heap file when using jconsole?
原标题:

Well this is embarrassing ...

I m starting to play with the Eclipse Memory Analyzer to look for Java memory leaks on a Windows box. Step 1 is to obtain a heap dump file. To do this I start my Java (javaw.exe) process from within Eclipse and connect to it with jconsole. Then on the jconsole MBeans tab I click the dumpHeap button. The first time I did this, I saw a pop-up saying it had created the heap dump file, but not giving its name or location. Now whenever I do a dumpHeap again while connected to a different javaw.exe process, jconsole says:

Problem invoking dumpHeap : java.io.IOException: File exists

and of course doesn t give its name or path. Where could it be?

I ve searched my C: drive (using cygwin command line tools) for files containing "hprof" or "java_pid" or "heapdump" and didn t find anything plausible. I ve even used the Windows search to look for all files in my Eclipse workspace that have changed in the last day.

I m using the Sun Java 1.6 JVM, and don t have -XX:HeapDumpPath set.

Update (28 April 2010): My original heap file location must have been determined by jconsole, the tool I triggered the heap dump from. The JVM s heap dump location must apply only to heap dumps it triggers (eg, on an OutOfMemoryException).

Matt B s suggestion to use jvisualvm nicely solves my problem by pointing me to a far more useful replacement for the old jconsole. It has a nice memory profiler that shows which types of objects are most numerous and hold the most memory. And it has a monitor that shows actual memory use over time. When you ask it for a heap dump, it tells you the file name even! The Eclipse Memory Analyzer gives you full details.

最佳回答

Try jvisualvm, it has a much better interface.

Note that starting with JDK version 6 update 7 or greater, Java VisualVM is bundled with JDK. See here.

问题回答

According to the docs for the Sun Java SE6 JVM:

By default the heap dump is created in a file called java_pid<pid>.hprof in the working directory of the VM

In Eclipse, the working directory is defined on the "Arguments" tab of the "Run Configurations" dialog. The default value is the same directory as the class that you are running.

why don t you set the first parameter for dumpHeap(String,boolean) when you try to invoke dumpHeap() from jconsole? it s the generated heapdump file s location and filename.

You could always use ProcessMonitor to see where it s trying to write to :) Done this myself in the past.

I found the dumped file into the same folder where the .bat file whic launch my java application is placed. (I m using windows 8.1, java 7) In my case jboss, /jboss-as/bin/ folder. To find it I searched * files, with today creation date and more than 200MB.





相关问题
Spring Properties File

Hi have this j2ee web application developed using spring framework. I have a problem with rendering mnessages in nihongo characters from the properties file. I tried converting the file to ascii using ...

Logging a global ID in multiple components

I have a system which contains multiple applications connected together using JMS and Spring Integration. Messages get sent along a chain of applications. [App A] -> [App B] -> [App C] We set a ...

Java Library Size

If I m given two Java Libraries in Jar format, 1 having no bells and whistles, and the other having lots of them that will mostly go unused.... my question is: How will the larger, mostly unused ...

How to get the Array Class for a given Class in Java?

I have a Class variable that holds a certain type and I need to get a variable that holds the corresponding array class. The best I could come up with is this: Class arrayOfFooClass = java.lang....

SQLite , Derby vs file system

I m working on a Java desktop application that reads and writes from/to different files. I think a better solution would be to replace the file system by a SQLite database. How hard is it to migrate ...

热门标签