Quick Troubleshooting Tips on Windows for Java SE 7
This "Quick Start Guide" gives you some quick tips for
troubleshooting. The subsections list some typical functions that
can help you in troubleshooting, including one or more ways to get
the information or perform the action.
These tips are organized as follows:
Hung, Deadlocked, or Looping
Process
Post-mortem Diagnostics, Memory Leaks
Monitoring
Other Functions
Hung, Deadlocked, or Looping
Process
- Print thread stack for all Java threads:
- Detect deadlocks:
- Request deadlock detection: JConsole tool, Threads tab
- Print information on deadlocked threads: Control-Break
- Print lock information for a process: jstack -l
pid
- Get a heap histogram for a process:
- Start Java process with -XX:+PrintClassHistogram, then
Control-Break
- jmap -histo pid
- Dump Java heap for a process in binary format to file:
- jmap -dump:format=b,file=filename pid
- Print shared object mappings for a process:
- Print heap summary for a process:
- Control-Break
- jmap -heap pid
- Print finalization information for a process:
- Attach the command-line debugger to a process:
- jdb -connect
sun.jvm.hotspot.jdi.SAPIDAttachingConnector:pid=pid
Post-mortem Diagnostics, Memory
Leaks
- Examine the fatal error log file. Default file name is
hs_err_pidpid.log in the working
directory.
- Create a heap dump:
- Start the application with HPROF enabled: java
-agentlib:hprof=file=file,format=b
application; then Control-Break
- Start the application with HPROF enabled: java
-agentlib:hprof=heap=dump application
- JConsole tool, MBeans tab
- Start VM with -XX:+HeapDumpOnOutOfMemoryError; if
OutOfMemoryError is thrown, VM generates a heap dump.
- Browse Java heap dump:
- Get a heap histogram for a process:
- Start Java process with -XX:+PrintClassHistogram, then
Control-Break
- jmap -histo pid
Monitoring
(jstat is not available on Windows 98 or Windows
ME.)
Note: The vmID argument for the jstat command is
the virtual machine identifier. See the
jstat man page for a detailed explanation.
- Print statistics on the class loader:
- Print statistics on the compiler:
- Compiler behavior: jstat -compiler vmID
- Compilation method statistics: jstat -printcompilation
vmID
- Print statistics on garbage collection:
- Summary of statistics: jstat -gcutil vmID
- Summary of statistics, with causes: jstat -gccause
vmID
- Behavior of the gc heap: jstat -gc vmID
- Capacities of all the generations: jstat -gccapacity
vmID
- Behavior of the new generation: jstat -gcnew
vmID
- Capacity of the new generation: jstat -gcnewcapacity
vmID
- Behavior of the old and permanent generations: jstat
-gcold vmID
- Capacity of the old generation: jstat -gcoldcapacity
vmID
- Capacity of the permanent generation: jstat
-gcpermcapacity vmID
- Monitor objects awaiting finalization:
- JConsole tool, VM Summary tab
- jmap -finalizerinfo pid
- getObjectPendingFinalizationCount method in
java.lang.management.MemoryMXBean class
- Monitor memory:
- Heap allocation profiles via HPROF: java
-agentlib:hprof=heap=sites
- JConsole tool, Memory tab
- Control-Break prints generation information.
Monitor CPU usage:
- By thread stack: java -agentlib:hprof=cpu=samples
application
- By method: java -agentlib:hprof=cpu=times
application
- JConsole tool, Overview and VM Summary tabs
- Monitor thread activity:
- JConsole tool, Threads tab
- Monitor class activity:
- JConsole tool, Classes tab
Actions on a Remote Debug
Server
First, attach the debug daemon jsadebugd, then execute
the command:
- Dump Java heap in binary format to a file: jmap
-dump:format=b,file=filename hostID
- Print shared object mappings: jmap hostID
- Print heap summary : jmap -heap hostID
- Print finalization information : jmap -finalizerinfo
hostID
- Print lock information : jstack -l hostID
- Print thread trace : jstack hostID
- Print Java configuration information: jinfo
hostID
Other Functions
- Interface with the instrumented Java virtual machines:
- Monitor for the creation and termination of instrumented VMs
(not Windows 98 or Windows ME): jstatd daemon
- List the instrumented VMs (not Windows 98 or Windows ME):
jps
- Provide interface between remote monitoring tools and local VMs
(not Windows 98 or Windows ME): jstatd daemon
- Request garbage collection: JConsole tool, Memory tab
- Print Java configuration information from a running process:
- Dynamically set, unset, or change the value of certain Java VM
flags for a process:
- Print command-line flags passed to the VM:
- Print Java system properties:
- Pass a Java VM flag to the virtual machine:
- jconsole -Jflag ...
- jhat -Jflag ...
- jmap -Jflag ...
- Print statistics of permanent generation of Java heap, by class
loader:
- Report on monitor contention:
- java -agentlib:hprof=monitor=y application
- Evaluate or execute a script in interactive or batch mode:
- Interface dynamically with an MBean, via JConsole tool, MBean
tab:
- Show tree structure.
- Set an attribute value.
- Invoke an operation.
- Subscribe to notification.
- Run interactive command-line debugger:
- Launch a new VM for the class: jdb class
- Attach debugger to a running VM: jdb -attach
address