内存泄漏情况和示例 ( 出现FullGC内存泄漏问题排查和分析)
导读:
老是出现堆内存不足,大量Full GC深知出现内存溢出应该怎么办,怎样通过排查找到源头分析来解决问题?
正文:
我们有个新服务上线运行一段时间后,老是出现堆内存不足,大量出现 Full GC,有些实例甚至出现内存溢出错误:
java.lang.OutOfMemoryError: Java heap space
但是为什么会内存溢出呢?按说访问量也不是很高,于是进行了下面的排查和分析。
1、怀疑内存泄漏
进入 APM 监控系统查看实例内存情况,把时间线拉长到一天,可以看到内存有缓慢上升趋势,初步怀疑有内存泄漏。
2、Heap Dump
获取到机器ip,联系运维人员去机器上把堆dump下来,dump命令:
/xxx/jdk1.8.0_212/bin/jmap -dump:live,format=b,file=/xxx/xxx.hprof 进程号
将堆dump文件 Xxx.hprof 下载到本地。
3、下载Heap Dump分析工具
常用的分析工具有MAT和JProfile,本文以MAT工具为示例进行分析。
注意:如果你本地安装的是JDK11 ,下载最新的即可;如果你本地安装的是JDK8,建议下载1.9.2版本。
4、将Dump文件导入MAT工具
MAT是eclipse的一个插件,免安装,双击打开即可使用。打开下载好的dump文件
5、分析Dump文件
打开内存泄漏怀疑分析报告,可以看到 SessionFactoryImpl 这个对象使用了 149M内存,占总内存的25%,这肯定不正常。SessionFactoryImpl 这个类是跟数据库相关,服务代码中使用了JPA作为持久层框架,应该是跟JPA相关,继续往下分析。
我们打开内存树,往下挖,可以看到 QueryPlanCache 这个对象占用内存比较大。
QueryPlanCache 表面的意思是:查询计划缓存。用google查一下具体含义。
简单来说Hibernate会缓存sql语句以减少重复编译,便于直接命中提高效率。在使用 SQL in 的时候,如果 in 后的参数不同,hibernate会把其当成不同的sql进行缓存,从而缓存大量的sql。
缓存的大小是多少?查了一下官方文档,如果不配置,这个缓存默认最大值为2048 。
Stack Overflow上也有用户反馈这个问题:https://stackoverflow.com/questions/31557076/spring-hibernate-query-plan-cache-memory-usage
常见的几种内存泄漏情况和示例(一次大量出现FullGC内存泄漏问题及内存溢出错误排查和分析)(8)
7、分析结论
drawio服务里面有大量的 sql in 语句,in 后面的参数不一样造成Hibernate缓存了大量SQL语句,占用大量的堆内存。
8、解决措施
(1)添加配置参数,限制缓存大小
参数解释:https://docs.jboss.org/hibernate/orm/5.4/userguide/html_single/Hibernate_User_Guide.html#configurations-query
(2)提高 sql in 的缓存效率
参数解释:https://docs.jboss.org/hibernate/orm/5.4/userguide/html_single/Hibernate_User_Guide.html#configurations-query
原文链接: https://www.yukx.com/architect/article/details/2363.html 优科学习网内存泄漏情况和示例 ( 出现FullGC内存泄漏问题排查和分析)
-
如何看到老年代、新生代的对象有哪些呢?MAT是分析dump的神器(顺便吐槽:当然也是吃内存卡机器的怪兽)。通常我们会在出现fullGC时dump下堆内存,然后分析FullGC的原因。那如何获知整个堆内存里,有哪些对象在新生代、哪些在老年代呢?一个典型的应用场景是:出现了耗时超预期的YoungGC,我
-
面向服务的架构(SOA)是一种软件开发方法,它使用称为服务的软件组件来创建业务应用程序。每项服务提供一种业务能力,并且服务也可以跨平台和语言相互通信。开发人员使用SOA来重用不同系统中的服务,或者组合几个独立的服务来执行复杂的任务。例如,一个组织中的多个业务流程需要用户身份验证功能。您可以创建一项身
-
1.背景1.1什么是交互式推荐?交互式推荐是一种互动式实时推荐产品模块,主要通过理解用户需求、以互动的方式进行推荐。交互式推荐由Youtube在2018年提出,主要用于解决推荐系统的延迟和与用户互动偏弱的问题。从2021年下半年开始,美团外卖推荐技术团队在外卖首页Feed上持续进行探索,2022上半
-
导读:老是出现堆内存不足,大量FullGC深知出现内存溢出应该怎么办,怎样通过排查找到源头分析来解决问题?正文:我们有个新服务上线运行一段时间后,老是出现堆内存不足,大量出现FullGC,有些实例甚至出现内存溢出错误:java.lang.OutOfMemoryError:Javaheapspace但
-
其实强引用、软引用、弱引用、虚引用这四个概念非常简单好记。在开头先总结一下这四个引用的特点吧。强引用:gc时不会回收软引用:只有在内存不够用时,gc才会回收弱引用:只要gc就会回收虚引用:是否回收都找不到引用的对象,仅用于管理直接内存接下来详细看看这四种引用,结合代码,深刻的体会一下。强引用即我们平
-
在Linux中,CPU主要用于中断、内核以及用户进程的任务处理,优先级为中断内核用户进程,在学习如何分析CPU消耗状况前。先要掌握三个重要的概念1、上下文切换每个CPU在同一时间只能执行一个线程,Linux采用的是抢占式调度,即为每个线程分配一定的执行时间,当到达执行时间、线程中有IO阻塞或高级优先