闲聊
❝
感谢各位居然有生之年上了一次榜单。没想到一次bug定位这么火,身为电商网站的后台开发,别的不敢说,jvm调优啊,bug定位啊,sql调优啊简直是家(ri)常(chang)便(chan)饭(shi)。后续也会努力给大家带来更多文章的
❞
就在上面文章发了没几天,生产又出问题了,一台服务cpu使用率飙到20%以上
查看gc日志发现,fullgc频繁,通过jstat排查,并没有释放多少内存【当时我再外面没有图】
通过分析,是hutool的WeakCache导致的,涉及业务逻辑修改,就不透露解决方案了,下面为大家分析下为啥会内存泄漏。
问题分析
WeakHashMap
「前置知识」之前写过一篇强软弱虚分析,感兴趣的可以点击看下。
我粗略的看了下,介不是弱引用吗,怎么会内存泄漏呢
「启动参数设置」-Xms50m -Xmx50m -XX:+PrintGCDetails
不嫌麻烦可以调大一点




WeakCache
下面有请下一位参赛选手WeakCache
凭借我一次次手点,发现,根本不回收,cacheMap不也是
WeakHashMap
咋不回收呢
搜了下issue,果然有人提过了,
「原文链接」 https://gitee.com/dromara/hutool/issues/I51O7M


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

既然不会删除,那是什么时候删除的呢?
彩蛋
那么这行代码是怎么存在这么久而不出问题的

原文始发于微信公众号(山间小僧):Hutool:WeakCache导致的内存泄漏
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/209023.html