如何以最短的停机时间在 windows 中进行堆转储?
How to take a heap dump in windows with minimum downtime?
我想弄清楚为什么 Elasticsearch 节点上的 JVM 堆使用率一直保持在 80% 以上。为了做到这一点,我通过 运行
进行堆转储
jmap.exe -heap:format=b 5348
(5348 是进程 ID)。然后我可以用 VisualVM 分析转储。
问题是 jmap
在进行转储时暂停了 JVM,因此节点基本上离线了大约 5 分钟。
This article 提出了一种更快的方法,该方法依赖于在 Linux 上使用 gdb
进行核心转储。我已经尝试过创建核心转储的 WinDbg,但我无法在 VisualVM 中使用它。
Windows是否有类似的方法?如何在几秒钟而不是几分钟内完成堆转储?
在 WinDbg
获取核心转储后,您需要 运行
从中提取堆转储
jmap -heap:format=b "C:\Program Files\Java\...\bin\java.exe" core.mdmp
这可以离线完成;不需要与 运行 Java 进程交互。然后就可以在VisualVM中打开生成的heap.bin
.
或者您可以使用 class 直方图。它的生成速度比完全堆转储快。
jmap -histo <PID>
它显示了 class 个实例在堆中占用最多 space 的实例列表。这些信息通常足以让我们了解记忆丢失的位置。
我想弄清楚为什么 Elasticsearch 节点上的 JVM 堆使用率一直保持在 80% 以上。为了做到这一点,我通过 运行
进行堆转储jmap.exe -heap:format=b 5348
(5348 是进程 ID)。然后我可以用 VisualVM 分析转储。
问题是 jmap
在进行转储时暂停了 JVM,因此节点基本上离线了大约 5 分钟。
This article 提出了一种更快的方法,该方法依赖于在 Linux 上使用 gdb
进行核心转储。我已经尝试过创建核心转储的 WinDbg,但我无法在 VisualVM 中使用它。
Windows是否有类似的方法?如何在几秒钟而不是几分钟内完成堆转储?
在 WinDbg
获取核心转储后,您需要 运行
jmap -heap:format=b "C:\Program Files\Java\...\bin\java.exe" core.mdmp
这可以离线完成;不需要与 运行 Java 进程交互。然后就可以在VisualVM中打开生成的heap.bin
.
或者您可以使用 class 直方图。它的生成速度比完全堆转储快。
jmap -histo <PID>
它显示了 class 个实例在堆中占用最多 space 的实例列表。这些信息通常足以让我们了解记忆丢失的位置。