Difference between revisions of "JVM Performance"
From Suhrid.net Wiki
Jump to navigationJump to searchLine 16: | Line 16: | ||
* Look at the GC logs. Turn on the verbosegc option | * Look at the GC logs. Turn on the verbosegc option | ||
* Look at the Full GC messages : [Full GC $before->$after($total), $time secs] | * 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 |
Revision as of 11:04, 8 December 2013
Tuning
- 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