您现在的位置是:亿华云 > 域名
记一次现网内存泄漏问题排查和分析
亿华云2025-10-09 01:21:51【域名】0人已围观
简介本文转载自微信公众号「爱笑的架构师」,作者雷小帅。转载本文请联系爱笑的架构师公众号。大家好,我是雷小帅!大家春节过得咋样,反正我是挺崩溃的。本来给自己列了好多计划,最终的执行效果是这样的:写几篇技术文
本文转载自微信公众号「爱笑的记次架构师」,作者雷小帅。现网泄漏析转载本文请联系爱笑的内存架构师公众号。
大家好,问题我是排查雷小帅!大家春节过得咋样,反正我是和分挺崩溃的。本来给自己列了好多计划,记次最终的现网泄漏析执行效果是这样的:
写几篇技术文章看几本技术书籍爽快玩了几天,走亲戚,内存看电影
哈哈,问题既然过年没好好学习,排查那只有熬夜赶作业了。和分
今天这篇文章带大家分析一个内存异常的记次问题,也算是现网泄漏析新年的第一篇技术文章了,开工大吉~~~
我们有个新服务上线运行一段时间后,内存老是出现堆内存不足,大量出现 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工具为示例进行分析。工具下载链接如下:
https://www.eclipse.org/mat/downloads.php
注意:如果你本地安装的是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
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
很赞哦!(13364)
相关文章
- 第六:这个圈子里的域名确实是赚钱的一些大玩家,至于小米农,有多少赚钱?几乎没有,也就是说,轿子里只有一个人,而且大多数人都抬着轿子。
- 你见过JS中的逗号表达式吗?这道逗号表达式的面试题,你能做对吗?
- 面试官:说一下类加载的过程
- 这么好用的Java单元测试工具,你还在犹豫什么?
- 其次,一般域名注册有一个获取密码的按钮,域名注册商点击后会向您发送密码。在得到域名注册商发送的密码后,将其传输到域名服务提供商网站,然后输入密码,此时域名呈现申请状态。提交申请后,原注册人通常会向您发送一封电子邮件,询问您是否同意转让。此时,您只需点击同意转移按钮,域名注册商就可以成功转移。
- JetBrains 调查:JavaScript 最流行,Python 超越 Java
- 我从大厂面试中学到的关于 C# 的知识
- Python实现之初等函数一
- 为了避免将来给我们的个人站长带来的麻烦,在选择域名后缀时,我们的站长最好省略不稳定的后缀域名,比如n,因为我们不知道策略什么时候会改变,更不用说我们将来是否还能控制这个域名了。因此,如果站长不是企业,或者有选择的话,如果不能选择域名的cn类,最好不要选择它。
- Flink 1.12 资源管理新特性回顾