GC调优的方法:
在我们做GC的调优之前,我们需要知道下面的事情:
- 多数的Java应用不需要在服务器上进行GC优化;
- 多数导致GC问题Java应用,都不是因为我们参数设置错误,而是代码问题;
- 在应用上线之前,先考虑将机器的JVM参数调整至最佳;
- 减少创建对象的数量;
- 减少使用全局变量和大对象;
- GC优化是到最后不得已才采用的手段;
- 在实际使用中,分析GC情况优化代码比优化GC参数要多得多
GC优化的目的:
1.将转移到老年代的对象数量降低到最小;
2.减少full GC的执行时间;
为了达到上面的目的,你需要做到的是:
· 减少使用全局变量和大对象;
· 调整新生代的大小到最合适;
· 设置老年代的大小为最合适;
· 选择合适的GC收集器
GC监控
真正熟练的使用GC调优,是建立在多次进行GC监控和调优的实战经验上,进行监控和调优的一般步骤为:
1.监控GC的状态
使用各种JVM的工具,查看当前日志,分析当前JVM参数设置,并且分析当前堆内存快照和GC日志,根据各区域的内存划分和GC执行时间,觉得是否进行优化
2.分析结果
如果各参数设置合理,系统没有超时日志出现,GC频率不高,GC耗时不高,那么没有必要进行GC优化;如果GC时间超过1-3s,或者频繁GC,则必须优化
PS:如果满足以下的指标,则一般不需要优化:
Minor GC执行时间不到50ms;Minor GC执行不频繁(约10s一次);Full GC执行时间不到1s;Full GC执行不算频繁(不低于10m一次)
3.调整GC类型和内存分配
4.不断地分析和调整
5.全面应用参数