垃圾回收器
垃圾回收调优
查看当前jvm的参数:在idea控制台输入,jdk的bin目录路径 -XX:+PrintFlagsFinal -version | findstr “GC”
明确:调优和应用,环境有关,要根据实际情况而定
调优领域
1)内存
2)锁竞争
3)cpu占用
4)io
确定目标
根据需要,选择合适的回收器
高吞吐量:ParallelGC
低延迟:CMS,G1,ZGC
新生代调优
新生代特点:
- 所有的new操作的内存分配非常廉价
- 死亡对象的回收代价是0
- 大部分对象用过即死
- Minor GC的时间远远低于Full GC
新生代调优最好的策略是加大内存,但是内存变大会存在问题,新生代内存变大,相应的老年代内存就会减少,如果老年代空间紧张,直接触发full gc,stw的时间长,建议是,大于堆内存的25%,小于堆内存的50%
老年代调优
以CMS为例
- CMS的老年代内存越大越好
- 先尝试不做调优,如果没有Full Gc,就已经很好了,否则先尝试调优新生代
- 观察发生Full GC时老年代内存占用,将老年代内存预设调大,1/4~1/3,jvm参数:-XX:CMSInitiatingOccupancyFraction=per
控制老年代,在老年代空间占用达到老年代总内存的per时,就使用CMS进行垃圾回收