Hutool:WeakCache导致的内存泄漏

闲聊

感谢各位居然有生之年上了一次榜单。没想到一次bug定位这么火,身为电商网站的后台开发,别的不敢说,jvm调优啊,bug定位啊,sql调优啊简直是家(ri)常(chang)便(chan)饭(shi)。后续也会努力给大家带来更多文章的 

image.png

 就在上篇文章发了没几天,生产又出问题了,一台服务cpu使用率飙到20%以上

查看gc日志发现,fullgc频繁,通过jstat排查,并没有释放多少内存【当时我再外面没有图】

通过dump出来的内存分析,是hutool的WeakCache导致的,涉及业务逻辑修改,就不透露解决方案了,下面为大家分析下为啥会内存泄漏。 

问题分析

WeakHashMap

「前置知识」之前写过一篇强软弱虚分析,感兴趣的可以点击看下。

我粗略的看了下,介不是弱引用吗,怎么会内存泄漏呢

「启动参数设置」-Xms50m -Xmx50m -XX:+PrintGCDetails不嫌麻烦可以调大一点

这个是没问题的,不会发生OOM

WeakCache

下面有请下一位参赛选手WeakCache 

 凭借我一次次手点,发现,根本不回收,cacheMap不也是WeakHashMap咋不回收呢 

搜了下issue,果然有人提过了,

「原文链接」 gitee.com/dromara/hut…

那么我们来实验下,把CacheObj拷贝出来,强制走我的

问题得到了解决,dalao牛逼 

既然不会删除,那是什么时候删除的呢?

是类似于懒删。 


彩蛋

那么这行代码是怎么存在这么久而不出问题的

image.png

不在那天爬的紫金山=。= 

image.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值