频繁full gc 如何排查
频繁full gc 通常表明应用程序在内存管理方面存在问题,可能导致性能下降,下面是排查步骤和一个详细的示例
排查步骤
- 收集GC日志
首先,需要开启详细的GC日志,在JVM参数中添加
-XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:/path/to/gc.log
- 分析GC日志
使用工具 GCViewer 分析GC日志,可以发现
- fullgc 频率
- 每次fullgc 耗时
- old gen使用情况,每次GC后仍然回收不掉
- 监控JVM内存使用情况
使用工具如 jvisualvm 监控jvm 内存使用
- eden区,频繁被填满后触发 minor gc
- Survivor 区:经常满载
- Old Gen 持续增长,即使 full gc 也难以下降。
- 分析堆内存
使用 jmap 生成 堆存储文件:
jmap -dump:format=b,file=heap_dump.hprof <pid>
使用jvisualvm 分析堆转储
- 检查代码中的内存使用 
- 调整JVM 参数 
临时调整 jvm 参数以缓解问题
-Xms4g -Xmx4g -XX:NewRatio=2 -XX:SurvivorRatio=8
- 优化代码 
- 验证改进 
- 总结 
- 使用GC日志和监控工具识别问题
- 通过堆内存分析找到内存泄漏的根源
- 优化代码内存的使用模式
- 调整JVM参数以更好适应应用特性
频繁full gc 如何排查的更多相关文章
- 一次频繁Full GC问题排查过程分享
		问题描述 应用收到频繁Full GC告警 问题排查 登录到对应机器上去,查看GC日志,发现YGC一分钟已经达到了15次,比Full GC还要频繁一些,其中Full GC平均10分钟超过了4次,如下图 ... 
- JVM 频繁 FULL GC 快速排查整理
		在分享此案例前,先聊聊哪些场景会导致频繁Full GC: 内存泄漏(代码有问题,对象引用没及时释放,导致对象不能及时回收)死循环大对象程序执行了System.gc() 尤其是大对象,80%以上的情况就 ... 
- 一次CMS GC问题排查过程(理解原理+读懂GC日志)
		这个是之前处理过的一个线上问题,处理过程断断续续,经历了两周多的时间,中间各种尝试,总结如下.这篇文章分三部分: 1.问题的场景和处理过程:2.GC的一些理论东西:3.看懂GC的日志 先说一下问题吧 ... 
- Hadoop记录-yarn ResourceManager Active频繁易主问题排查(转载)
		一.故障现象 两个节点的ResourceManger频繁在active和standby角色中切换.不断有active易主的告警发出 许多任务的状态没能成功更新,导致一些任务状态卡在NEW_SAVING ... 
- [转]一次CMS GC问题排查过程(理解原理+读懂GC日志)
		这个是之前处理过的一个线上问题,处理过程断断续续,经历了两周多的时间,中间各种尝试,总结如下.这篇文章分三部分: 1.问题的场景和处理过程:2.GC的一些理论东西:3.看懂GC的日志 先说一下问题吧 ... 
- 系统假死——系统频繁Full gc问题分析
		主要可能的原因: 1,eden区太小,eden和survivor默认比例是8:12,old区太小,新生代和老年代的比例也可以调节的.3,是否程序会分配很多短期存活的大对象,程序本身是否有问题? 进入老 ... 
- Android面试题集
		前几天整理了Java面试题集合,今天再来整理下Android相关的面试题集合.假设你希望能得到最新的消息,能够关注https://github.com/closedevice/interview-ab ... 
- [转] 总结了N个真实线上故障
		以下文章来源于架构师进阶之路 ,作者二马读书 1. JVM频繁FULL GC快速排查 在分享此案例前,先聊聊哪些场景会导致频繁Full GC: 内存泄漏(代码有问题,对象引用没及时释放,导致对象不能及 ... 
- 线上排查:内存异常使用导致full gc频繁
		线上排查:内存异常使用导致full gc频繁 问题系统 日常巡检发现,应用线上出现频繁full gc 现象 应用线上出现频繁full gc 排查过程 分析dump 拉dump文件:小插曲:dump时如 ... 
- GC Ergonomics间接引发的锁等待超时问题排查分析
		1. 问题背景 上周线上某模块出现锁等待超时,如下图所示: 我虽然不是该模块负责人,但出于好奇,也一起帮忙排查定位问题. 这里的业务背景就是在执行到某个地方时,需要去表中插入一批数据,这批数据需要根据 ... 
随机推荐
- vue 实现组件全屏展示及退出
			vue 实现组件全屏展示及退出 一.组件 采用 vue-fullscreen 组件 二.实现方式 <fullscreen ref="fullscreen" @change=& ... 
- Servlet——Request请求转发
			Request请求转发 特点: 
- SuperMap iServer&iPortal&iEdge结合CAS 5.3服务器实现单点登录
			2023-10-19 更新,由于阿里云maven镜像仓库里缺失了很多CAS5.3 依赖,如果缺少可以用附件里的同步到本地仓库 链接:https://pan.baidu.com/s/14DhRci_Am ... 
- Transformer原理+代码详解
			简介 Transformer是一种深度学习模型,它在自然语言处理(NLP)领域中非常流行和有效.它最初由Vaswani等人在2017年的论文<Attention is All You Need& ... 
- 0201-PyTorch0.4.0迁移指南以及代码兼容
			0201-PyTorch0.4.0迁移指南以及代码兼容 目录 一.概要 二.合并Tensor和Variable和类 2.1 Tensor中的type()改变了 2.2 什么时候autograd开始自动 ... 
- kotlin类与对象——>对象表达式与对象声明、内联类
			1.对象表达式与对象声明 有时候,我们需要创建一个对某个类做了轻微改动的类的对象,而不用为之显式声明新的子类.Kotlin 用对象表达式和对象声明处理这种情况 2.对象表达式 要创建一个继承自某个(或 ... 
- Android复习(二)应用资源——>菜单
			菜单资源定义可通过 MenuInflater 进行扩充的应用菜单,包括选项菜单.上下文菜单和子菜单. 有关使用菜单的指南,请参阅菜单开发者指南. 文件位置: res/menu/filename.xml ... 
- KubeSphere 集群配置 NFS 存储解决方案
			作者:申红磊,QingCloud 容器解决方案架构师,开源项目爱好者,KubeSphere Member 在正式阅读本文之前,先友情提醒一下:不建议您在生产环境中使用 NFS 存储(特别是 Kuber ... 
- C++刷题小知识点
			数据结构定义 struct ListNode { int val; ListNode *next; ListNode() : val(0), next(nullptr) {} ListNode(int ... 
- DOS下的网络管理命令
			DOS下的网络管理命令 一. 实验目的 掌握DOS下的网络管理命令 二. 实验内容和要求 在DOS环境下用不同的网络管理命令,实现不同的网络管理功能 三. 实验方法.步骤及结果测试 1. 原理分析及 ... 
