Difference between revisions of "JVM Performance"
From Suhrid.net Wiki
Jump to navigationJump to search (→Tuning) |
|||
Line 1: | Line 1: | ||
= Tuning = | = Tuning = | ||
+ | |||
+ | Notes from [http://www.infoq.com/presentations/JVM-Performance-Tuning-twitter] | ||
* Biggest contributor to latency is the Garbage Collector | * Biggest contributor to latency is the Garbage Collector |
Revision as of 11:13, 8 December 2013
Tuning
Notes from [1]
- Biggest contributor to latency is the Garbage Collector
- Areas of Tuning : Memory, Lock Contention, CPU Usage, I/O
- Areas of Memory Tuning:
- Memory footprint tuning
- Allocation rate tuning
- GC tuning
Memory footprint tuning
- It's all about ensuring that the GC has less work to do
- One of the classic symptoms is the OutOfMemoryError
- Why ? It can be too much data, or the data representation is "fat", or there is a memory leak in the app code
- What is too much data ?
- Look at the GC logs. Turn on the verbosegc option
- Look at the Full GC messages : [Full GC $before->$after($total), $time secs]
- If more memory can be added, add it.
- Do we actually need ALL that data in memory, consider using techniques such as LRU cache & Soft References