博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
记录一次线上GC问题和原因分析,FullGC到一定次数就停止FullGC
阅读量:6000 次
发布时间:2019-06-20

本文共 805 字,大约阅读时间需要 2 分钟。

hot3.png

症状

启动之后,Full GC频繁,Young GC几乎没有,由于GC频繁,cpu使用率过高,触发报警,大概一个小时之后,也可能是几个小时之后,也可能是几十分钟之后,Full GC停止,稳定在一个数字,然后一切正常。

JVM启动参数

-Xms$VM_XMS -Xmx$VM_XMX -Xmn$VM_XMN -Xss$VM_XSS -XX:ParallelGCThreads=20 -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+UseCMSCompactAtFullCollection -XX:SurvivorRatio=65536 -XX:MaxTenuringThreshold=0 -XX:CMSInitiatingOccupancyFraction=80

问题猜测

SurvivorRatio=65536 MaxTenuringThreshold=0

这两个参数有问题,一个是from to 区很小,64K,另一个是一个对象在GC时,如果存活,或者说不是垃圾,就直接放到老年代。
系统刚刚启动的时候,由于会初始化很多东西,所以有一次两次Full GC是正常的,之后就会有正常的young GC,Full GC很少或者几乎没有。但是使用了这两个参数,会导致一个问题,系统启动时的一次两次Full GC发现了大量存活的对象,要往老年代放,但是老年代的地方也不够,然后又会触发Full GC,触发了之后,又有对象要往老年代放,老年代不够,又触发,如此反复。直到到达一个平衡点,一次Full GC收到的对象很少,老年代足够放下,不再触发Full GC,这样系统才会回到多次Young GC,很少Full GC的状态。

转载于:https://my.oschina.net/wuxiaofei/blog/2396254

你可能感兴趣的文章
22. Generate Parentheses
查看>>
MDL相关总结
查看>>
抓取代理IP
查看>>
【Matlab 】【转】元胞数组--cell
查看>>
python2.7.2文档阅读笔记
查看>>
jQuery技巧之让任何组件都支持类似DOM的事件管理
查看>>
Python中模块的发布与安装
查看>>
The Image Gallery Revisited
查看>>
cc2530 timer 3 PWM <可调占空比>
查看>>
Centos 修改limits.conf open files后不生效的解决办法
查看>>
kibana多台服务部署
查看>>
使用git将项目上传到github
查看>>
Git常用命令总结
查看>>
算法时间复杂度
查看>>
什么是ARC
查看>>
xml的生成与解析_老师笔记
查看>>
Algs4-1.4.33 32位计算机中的内存需求
查看>>
Ubuntu 16.04系统下CUDA8.0配置Caffe教程
查看>>
Redis.py客户端的命令总结【二】
查看>>
linux shell 数组的使用
查看>>