一次异常OOM问题学习跟踪的过程
摘要
春节后第一周一个项目出现了OOM的问题.
平台研发和产品研发跟踪了接近一周的时间也没有最终确认问题根因.
这里总结一下整个过程, 希望以后在遇到相同问题时会有进一步的结论.
产品的稳定运行离不开所有人的努力. 不管是框架,产品平台还是其他.
现象和暂时的结论
产品需要在月初处理一个月度数据.
但是最近发现处理过程非常缓慢,并且经常无法处理完成.
并且会导致处理数据的服务器卡顿.CPU暴高.出现响应变慢的问题.
后台进行了mat的分析工作. 然后发现有一个可以的memory leak
但是比较奇怪的是 他的对象名为 hibernate的queryplancache里面包含了 完全相同的 接近3000个表的信息
每一个里面有 11k 这么大,并且对象有 接近200万个, 直接导致 占用了 20G的对内存.
导致异常.
根据平台开发的分析. 发现此处可能为hibernate的bug:
理论上默认值 hibernate 的 queryplancache 最多占用2G的内存, 但是实际上占用了20G.
应该是业务的代码触发了hibernate的bug导致缓存信息放到内存中没有释放,出现了OOM.
分析过程
获取返回过来的 dump 文件, 使用 mat 进行简要分析
打开 leak suspect 进行查看
建议可以先查看 系统的概要信息对系统有一个简单的了解:
Leak Suspects
» System Overview
System Overview
Heap Dump Overview
System Properties
Thread Overview
Top Consumers
Class Histogram
打开 Problem Suspect 1
理论上第一个问题的概率最高
建议选中detail 打开详细进行查看.
在memory leak的界面可以看到很多内容.
The thread org.apache.tomcat.util.threads.TaskThread @ 0x5e901df80 http-nio-5200-exec-2
keeps local variables with total size 6,885,096,656 (66.41%) bytes.
此命令会将 占用最多内存的堆栈信息展示出来. 存在未的风险是最大的.
Shortest Paths To the Accumulation Point
累积点的最短路径
Accumulated Objects in Dominator Tree
累积对象所在树
Accumulated Objects by Class in Dominator Tree
对象树种按照类进行分组的对象信息
All Accumulated Objects by Class
按照类进行分组的所有的对象信息
Thread Details
线程信息
Thread http-nio-5200-exec-2
Thread Properties
Thread Stack
线程堆栈信息
最快分析方法
打开最后面的 Thread Details -> Thread Stack
可以反馈给对应开发. 确认问题场景等.
打开 All Accumulated Objects by Class
可以查看哪些对象 占用内存最多
可以通过这个内容 确定上一个场景里面的业务数据, 便于研发人员进一步的定位问题原因.
发现精确的数据, 比如发现excel的文件信息. 发现异常的用户id等.
打开 Accumulated Objects by Class in Dominator Tree
或者是上面一个 可以看到对象的上下级信息, 便于分析是那一块的问题
可以快速发现是否是产品bug或者是比较深层次的问题.
关于 in going 以及out going 等名词的含义
in going: 查看对象被谁引用,右键->list objects -> with ingoing references
out going: 查看对象为什么耗内存,我们看到一个线程池占用了>25mb的内存,右
键->list objects -> with outgoing references
Shallow Size: 对象自身占用的内存大小,不包括它引用的对象
Retained Size:被GC后Heap上释放的内存大小,
即当前对象大小+当前对象可直接或间接引用到的对象的大小总和
一次异常OOM问题学习跟踪的过程的更多相关文章
- C++异常中的堆栈跟踪
C++语言的运行时环境是基于栈的环境,堆栈跟踪(trace stack)就是程序运行时能够跟踪并打印所调用的函数.变量及返回地址等,C++异常中的堆栈跟踪就是当程序抛出异常时,能够把导致抛出异常的语句 ...
- OutOfMemory相关问题(内存溢出异常OOM)
OutOfMemory(内存溢出异常OOM) java.lang.OutOfMemoryError :Thrown when the Java Virtual Machine cannot alloc ...
- JVM学习笔记——类加载过程
JVM学习笔记——类加载过程 类加载模型——双亲委派模型(Parents Delegation Model)也可称为“溯源委派加载模型” Java的类加载器是一个运行时核心基础设施模块,主要是启动之初 ...
- Java虚拟机JVM学习03 连接过程:验证、准备、解析
Java虚拟机JVM学习03 连接过程:验证.准备.解析 类被加载后,就进入连接阶段. 连接就是将已经读入到内存的类的二进制数据合并到虚拟机的运行时环境中去. 连接阶段三个步骤:验证.准备和解析. 类 ...
- (二)我的Makefile学习冲动&&编译过程概述
前言 一 年轻的冲动 二 学习曲线 1 Makefile基本语法 2 bash基础 3 world 三 编译过程概述 1 主机预装工具 2 编译host工具 3 编译交叉工具链 4 编译内核模块 5 ...
- Linux内核分析第一周学习博客 --- 通过反汇编方式学习计算机工作过程
Linux内核分析第一周学习博客 通过反汇编方式学习计算机工作过程 总结: 通过这次对一个简单C程序的反汇编学习,我了解到计算机在实际工作工程中要涉及大量的跳转指针操作.计算机通常是顺序执行一条一条的 ...
- SQLNET跟踪tnsping过程
原文地址:SQLNET跟踪tnsping过程 作者:yingyifeng306 sqlnet是oracle提供的与网络层面交互的一个工具,比如如何解析客户端发起的连接,如何对客户端发起的连接进行辨别, ...
- Java学习的一般过程
伴随着科学技术的不断发展,世界开始走向信息化.网络化.大数据化.自然而然,计算机专业变得十分热门.尽管如此,计算机专业人才对社会来说仍然是供不应求,当然,这里指的是高层次技术人才.因此,对于我们这些占 ...
- 在学习python的过程中,遇到的最大的困难是什么?
本人文科生,回顾自己近 2 年的Python 自学经历,有一些学习心得和避坑经验分享给大家,让大家在学习 Python 的过程中少走一些弯路!减少遇到不必要的学习困难! 首先,最开始最大的困难应该就是 ...
- [持续更新] Python学习、使用过程中遇见的非代码层面知识(想不到更好的标题了 T_T)
写在前面: 这篇博文记录的不是python代码.数据结构.算法相关的内容,而是在学习.使用过程中遇见的一些没有技术含量,但有时很令人抓耳挠腮的小东西.比如:python内置库怎么看.python搜索模 ...
随机推荐
- Python——第一章:语言介绍
随着Python的语言在世界受欢迎程度持续高涨,如今也成功夺得了第一的宝座. 在计算机领域,没有谁(诺基亚.微软.苹果.亚马逊等等)能永远稳坐第一,随着时间更迭,就会推陈出新,一定会有更好的.更先进的 ...
- python异步编程之asyncio低阶API
低阶API介绍 asyncio中低阶API的种类很多,涉及到开发的5个方面.包括: 获取事件循环 事件循环方法集 传输 协议 事件循环策略 本篇中只讲解asyncio常见常用的函数,很多底层函数如网络 ...
- Blazor技术入门
曾写过点儿前后端分离的项目(Vue+.NET Core Web API).WPF和WinForm.因为Blazor不支持小程序的原因(相对于uniapp),所以只是大概知道Blazor可以写Web.P ...
- mac phpbrew安装
php 编译安装php 7.2.26 aliyun 镜像中心:https://developer.aliyun.com/mirror/ 1.安装brew /usr/bin/ruby -e " ...
- 华为云MVP朱有鹏:做IoT开发乐趣无穷,年轻开发者更要厚积薄发
[摘要] 可以预见的是,AIoT会是未来一段时间主流的技术趋势方向,当前也有不少科技巨头涌入其中,蓄势待发,而5G的到来加速了AIoT产业的扩张速度,所以如华为云MVP朱有鹏所说,年轻的开发者应该要拥 ...
- 华为云 UCS (On-Premises):运行在您本地数据中心的CCE集群
摘要:华为云分布式云原生UCS服务,是面向分布式云场景下的新一代云原生产品,提供UCS (Huawei Cloud).UCS (Partner Cloud).UCS (Multi-Cloud).UCS ...
- 全网呕血整理:关于YOLO v3原理分析
摘要:YOLO系列的目标检测算法可以说是目标检测史上的宏篇巨作,接下来我们来详细介绍一下YOLO v3算法内容. 算法基本思想 首先通过特征提取网络对输入特征提取特征,得到特定大小的特征图输出.输入图 ...
- 华为云发布CodeArts Req需求管理工具,让需求管理化繁为简
摘要:华为云正式发布CodeArts Req,这是一款自主研发的软件研发管理与团队协作工具,旨在助力企业大规模研发转型成功,释放组织生产力. 本文分享自华为云社区<华为云发布CodeArts R ...
- 拔掉电源会怎样?GaussDB(for Redis)双活让你有备无患
摘要:GaussDB(for Redis)推出双活方案,助力全球化业务部署,为您的数据资产保驾护航! 本文分享自华为云社区<华为云GaussDB(for Redis)揭秘第22期:拔掉电源会怎样 ...
- 7000+字图文并茂解带你深入理解java锁升级的每个细节
摘要:对于java锁升级,很多人都停留在比较浅层的表面理解,这篇7000+字和图解带你深入理解锁升级的每个细节. 本文分享自华为云社区<对java锁升级,你是否还停留在表面的理解?7000+字和 ...