Java Virtual Machine Profiling

Download as ppt, pdf, or txt
Download as ppt, pdf, or txt
You are on page 1of 18

Java Virtual Machine Profiling

Agenda
Introduction
JVM overview
Performance concepts
Monitoring
Profiling
VisualVM demo
Tuning
Conclusions

Introduction
What? Monitoring JVM -> Profiling JVM -> Tuning
Who? Java SE developers, Java EE developers, Java
architects, Java apps admin
What not? SO perf, I/O perf, Network perf, JIT perf
JVM overview
Performance basics
Memory footprint
Startup time
Scalability
Responsiveness
Throughput
Performance methodology
Monitoring
Not intrusive: observe behavior, not overload
For development/production
For troubleshooting: identify issues
Tuning info for: JVM issues (heap size, GC optimization, JIT bugs)
Profiling
More intrusive: analyze your code, cause overload
For development: get performance data in a running app
For troubleshooting: focus on the issues
Tuning info for: code issues (memory leaks, lock contentions)
Tuning
Known performance requirements
Monitoring and/or profiling, then compare with requirements
Modify JVM arguments or source code
Incorporating performance in development
Analysis -> Design -> Code -> Benchmark -> Profile -> Deploy
Tools for monitoring
-verbose: gc,
-XX:+PrintGCDetails, -XX:PrintCompilation
Jstat
JConsole, VisualVM, VisualGC
Monitoring
What to monitor?
CPU usage
Java heap usage,
# of threads
GC: frequency and duration
JIT: frequency, duration, opt/de-opt cycles, failed compilations
Result
Identify Java heap tuning
GC tuning

Heap profiling
When: GC runs frequently, large Java heap
Look for: very large allocated objects, small objects allocated at a high rate
Output: throughput/responsiveness issues, memory allocation patterns, memory
strategies (alternative APIs, caching solutions)

Profiling
CPU profiling
When: large amount of CPU time
Look for: methods with a high self-time
Output: throughput issues, identify algorithm and designs issues
Memory leaks: reference to allocated object remains unintentionally reachable and
cannot be GC'ed.
When: Java heap grow over time w/o bound, OOM errors
Look for: abnormal memory consumption,
Output: code errors
Profiling (continued)
Lock contention: large number of context switches, related to CPU utilization
When: manual use of threads
Look for: high number of context switches, many threads in wait state
Output: code errors.
Tools for profiling
Netbeans profiler
jmap, jhat
-XX: +HeapDumpOnOutOfMemoryError
VisualVM
Profiling tecniques
Sampling Profiling
Code modification No Yes, at bytecode level in startup time.
Overhead
Only when sampling, depends of
frequency of sampling.
Large, depends of number of
instrumented methods and number of
threads.
Accuracy
Not to much, better with high
frequency
Accurate
Repeatability Different results in different measures Similar results
When?
Synchronization problems
Profiling a production application
Identify performance bottlenecks
Analyze performance bottlenecks
Precise information
Included in <JDK_HOME>/bin for JDK 1.5+, except jhat (JDK 6+) and jvisualvm (JDK 6
update 7+)

jps: list the instrumented HotSpot VMs for the current user in the target system.
jinfo: prints system properties and command-line flags used in a JVM
jmap: prints memory related statistics for a running VM or core file
jhat: parses a heap dump in binary format and starts an HTTP server to browse different
queries (JDK 6)
jstat: provides information on performance and resource consumption of running
applications using the built-in instrumentation in the HotSpot VM.
jstack: prints the stack traces of all the threads attached to the JVM, including Java
threads and VM internal threads. Also performs deadlock detection
jconsole: uses the build-in JMX instrumentation in the JVM to provide information on
performance and resource consumption of running applications
jvisualvm: useful to troubleshoot applications and to monitor and improve applications
performance. It helps ot generate and analyze heap dumps, track down memory leaks,
perform and monitor garbage collection, and perform lightweigth memory and CPU
profiling.
Profiling tools
Profiling tools (continued)
Profiling tools (continued)
Start VisualVM
# <JVISUALVM_HOME>/bin/visualvm -jdkhome <JDK_HOME>
VisualVM demo
The bleeding-edge distribution of jvisualvm, with the latest features
and bug fixes.
Download software: http://visualvm.java.net/ (current version 1.3.5)
Enable JVM profiling
-Dcom.sun.management.jmxremote=true: Registers the JVM
instrumentation MBeans and publishes the RMI connector via a private
interface to allow JMX client applications to monitor a local JVM.
-Xshare:off: Disable class data sharing
-javaagent:<VISUALVM_HOME>/profiler/lib/jfluid-server.jar: Specify
where is the profiler agent
Java heap and stack tuning



Tuning
Heap and lock contention issues:
Avoid create objects where primitives could be used (autoboxing is not for free)
Avoid String concatenations, use StringBuilder with append()
Avoid StringBuilder overallocation, set initial size to reduce resizing
Avoid use of synchronized keyword, look for a java.util.concurrent solution
Use java.util.concurrent API instead of "synchronized" Collections
Don't use exceptions for flow control (Exception objects allocation), use flow
control constructs (if/else, return, switch).
Don't generate stack traces, they're expensive operations.
Reduce number of system calls:
Avoid accessing disk: use large buffers or direct buffering
Avoid accessing to underlying OS
Avoid processing bytes and characters individually
Never implement finalize(): pain in the ass for GC

GC issues: not covered



Tuning (continued)



Conclusions
JDK offers very useful utilities to troubleshoot and manage
performance issues with JVM.
We can use them not only when a performance issue
happens, but to understand what is the behavior of the
application and where could be improve it.
Incorporate performance benchmarks in your development
cycle.
Thanks!
Memory Management in the Java HotSpot Virtual Machine
http://java.sun.com/j2se/reference/whitepapers/memorymanagement_whitepaper.pdf
Troubleshooting Guide for Java SE 6 with HotSpot VM
http://www.oracle.com/technetwork/java/javase/toc-135973.html
JDK Utilities
http://download.oracle.com/javase/6/docs/technotes/tools/share/jps.html
http://download.oracle.com/javase/6/docs/technotes/tools/share/jinfo.html
http://download.oracle.com/javase/6/docs/technotes/tools/share/jmap.html
http://download.oracle.com/javase/6/docs/technotes/tools/share/jhat.html
http://download.oracle.com/javase/6/docs/technotes/tools/share/jstat.html
http://download.oracle.com/javase/6/docs/technotes/tools/share/jstack.html
http://download.oracle.com/javase/6/docs/technotes/tools/share/jconsole.html
http://download.oracle.com/javase/6/docs/technotes/tools/share/jvisualvm.html
Visual VM
http://visualvm.java.net/
JVM HotSpot options
http://www.oracle.com/technetwork/java/javase/tech/vmoptions-jsp-140102.html

References

You might also like