OpenJDK 上如何产生含内存内容的 Systemdump,类似 IBM 的 com.ibm.jvm.Dump.SystemDump()

2023-04-12 17:10:57 +08:00
 matepi

很多时候单单通过 heapdump 来分析 oom 还是比较困难

因为 oom 里面只存在内存结构、而没有内存内容

有些开发设计上的做法,交易内容存储放在公共的 list/map 类型的对象中,而不是对象 Bean 中。

此时,对于交易内存溢出的情况,只看到一个大 list/map 对象过大溢出,但明确不了具体是哪个交易、占据了公共类 list/map 式对象、各自多少,就很难查明原因。

IBM JDK 可以使用 SystemDump 来得到一个含有内存对象内容的 SystemDump 。从对象字符串实际内容来寻找交易根源、原因。

那么对应 OpenJDK 的获取 SystemDump 方式是什么呢?

1074 次点击
所在节点    Java
3 条回复
feedcode
2023-04-12 19:32:50 +08:00
> 因为 oom 里面只存在内存结构、而没有内存内容
这个结论就是错的,假如 heap 是 64G ,那 dump 就是 64G 的拷贝, 如果你看不到内存内容,那你用的工具不对或者文件不完整(磁盘空间不够)
RuralHunter
2023-04-12 22:25:20 +08:00
没错,既然叫 heapdump ,显然是把整个 heap 都 dump 出来了,怎么可能没有内容。
matepi
2023-04-13 09:08:40 +08:00
@feedcode
@RuralHunter
确实,找了台 openjdk 环境试了一下,openjdk jmap 出来的 heapdump 是有内容的。
用 IBM JDK 的 heapdump 没内容实现,去猜测 openjdk 的实现,是我不对了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/931985

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX