我想弄清楚为什么 Elasticsearch 节点上的 JVM 堆使用率一直保持在 80% 以上。为了做到这一点,我通过运行进行堆转储
jmap.exe -heap:format=b 5348
(5348 是进程 ID)。然后我可以用 VisualVM 分析转储。
问题是jmap
在进行转储时暂停 JVM,因此节点基本上离线大约 5 分钟。
本文提出了一种更快的方法,该方法依赖于gdb
在 Linux 上使用 coredump。我已经尝试过创建核心转储的 WinDbg,但我无法在 VisualVM 中使用它。
Windows有类似的方法吗?如何在几秒钟而不是几分钟内完成堆转储?