开发者

Can I generate an HPROF file at will?

开发者 https://www.devze.com 2022-12-21 04:35 出处:网络
I have a java process which is actin开发者_StackOverflow社区g dubiously. I\'d like to see what\'s up using the various HPROF analysis tools.

I have a java process which is actin开发者_StackOverflow社区g dubiously. I'd like to see what's up using the various HPROF analysis tools.

How do I generate one on the fly?


Yes. You can generate an hprof file (containing heap memory usage) on the fly using the jmap tool, which ships with Sun's Java VM:

jmap -dump:file=<file_name> <pid>


You have to start the Java process with the correct arguments, which vary a little depending on the JVM version. Then, send a QUIT signal to the process to generate a new file.

The output is normally generated when the VM exits, although this can be disabled by setting the “dump on exit” option to “n” (doe=n). In addition, a profile is generated when Ctrl-\ or Ctrl-Break (depending on platform) is pressed. On Solaris OS and Linux a profile is also generated when a QUIT signal is received (kill -QUIT pid). If Ctrl-\ or Ctrl-Break is pressed multiple times, multiple profiles are generated to the one file.


VisualVM can help you dig into what your process is doing, including the ability to arbitrarily force a heap dump on a running process.


jconsole now has the ability to create a dump to the app's current working directory.

  1. Connect to your JMX enabled instance
  2. Navigate to com.sun.management-->HotspotDiagnostic-->Operations
  3. Fill in p0 to name the Heap Dump
  4. press the heapDump button

Jconsole Screen Shot

0

精彩评论

暂无评论...
验证码 换一张
取 消