一般jvm调优可以从三个方面去调优
1、调整新生代的大小到最合适和老年代的大小最合适(上线的时候)
2、选择合适的GC回收器
3、代码的调优
首先通过在线上服务通过命令行jps -vVml,查找你当前项目的服务的id
然后通过jstat -gc <服务的id>,查看新生代触发的次数,以及垃圾回收所消耗的时间,查看老年代触发的次数,以及垃圾回收所消耗的时间。
并且通过打开GC日记,或者是jmap -heap 查看内存的使用情况,如果是内存导致的问题,可以通过设置jvm的参数提高内存-Xms -Xmx。
通过jmeter压力测试,发现G1的处理响应时间和吞吐量比其他的GC回收器更优
注:如果满足下面的指标,则一般不需要进行GC:
Minor GC执行时间不到50ms;
Minor GC执行不频繁,约10秒一次;
Full GC执行时间不到1s;
Full GC执行频率不算频繁,不低于10分钟1次;
经验总结:
在内存相对紧张的情况下,可以按照上述的方式来进行内存的调优, 找到一个在GC频率和GC耗时上都可接受的一个内存设置,可以用较小的内存满足当前的服务需要
但当内存相对宽裕的时候,可以相对给服务多增加一点内存,可以减少GC的频率,GC的耗时相应会增加一些。 一般要求低延时的可以考虑多设置一点内存, 对延时要求不高的,可以按照上述方式设置较小内存。
补充:
永久代(方法区)并不在堆内,所以之前有看过一篇文章中描述的 整个堆大小=年轻代+年老代+永久代的描述是不正确的。