莫方教程网

专业程序员编程教程与实战案例分享

MyBatis居然也有并发问题(下:Hutool:WeakCache导致的内存泄漏

就在上篇文章发了没几天,生产又出问题了,一台服务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牛逼

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

是类似于懒删。



作者:山间小僧
链接:https://juejin.cn/post/7267445093836128314

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言