前言:提高Java性能需要避免FGC,尽量在YGC里解决问题,本文以一则线上真实的案例来分析因为内存过大导致YGC不了,甚至FGC都不行,导致CPU持续100%,以及这个中间年轻代,年老代的变化。
本文给出一个重要的推论CPU持续100%意味着系统出什么问题?可以用于线上问题快速定位。
现象:线上服务器CPU打到100%。
查看内存在1分钟左右增加1G以上

从图中可以看出网络流量突发很厉害。
再看具体的网络流量图

单独看出流量就行了,出流量非常大:

查看调用链
本文通过线上实例分析,讲述了由于内存过大导致YGC和FGC失效,使得CPU持续100%的情况。问题表现为网络流量突发,接口超时,日志显示大对象无法释放。解决方案包括避免大数据量查询,实施分页,并考虑调整年轻代内存大小以适应系统QPS和接口数据大小。
前言:提高Java性能需要避免FGC,尽量在YGC里解决问题,本文以一则线上真实的案例来分析因为内存过大导致YGC不了,甚至FGC都不行,导致CPU持续100%,以及这个中间年轻代,年老代的变化。
本文给出一个重要的推论CPU持续100%意味着系统出什么问题?可以用于线上问题快速定位。
现象:线上服务器CPU打到100%。
查看内存在1分钟左右增加1G以上

从图中可以看出网络流量突发很厉害。
再看具体的网络流量图

单独看出流量就行了,出流量非常大:

查看调用链
2586

被折叠的 条评论
为什么被折叠?