gpt4 book ai didi

java - GC开销限制异常: Unable to take threads & heap dump

转载 作者:行者123 更新时间:2023-11-30 02:29:10 25 4
gpt4 key购买 nike

我们的服务器面临GC开销限制异常,我们无法进行堆和线程转储,因为它给出了一些异常。如何着手解决这个问题?有人可以帮忙吗?

最佳答案

获取堆和线程转储的正常方法依赖于 JMX 和所谓的 VM 操作。

GC 本身就是一个 VM 操作,因此在它完成之前,下一个 VM 操作无法启动(并且 JMX 是用 Java 实现的,因此它也会作为 Stop-the-World 暂停的一部分而被阻止)。

您可以尝试在 JDK 暂停时对 jstackjmap 命令使用 -F 选项。强制模式是使用操作系统调试功能来访问 JVM 进程内存,不需要 JVM 进程的“配合”。

另一个有用的选项是jmap -J-Dsun.tools.attach.attachTimeout=120000 ...,这会增加jmap等待JVM响应的超时时间。

如果 JVM 实际上因 OOME 崩溃,

-XX:+HeapDumpOnOutOfMemoryError 是另一个选项。

-XX:HeapDumpPath=filename 选项允许您控制生成的堆转储的路径。

这两个标志都可以在运行时使用 jinfo 进行修改。例如。

jinfo -flag +HeapDumpOnOutOfMemoryError <PID>
jinfo -flag HeapDumpPath=mydump.hprof <PID>

最后,您可以获取操作系统特定的核心转储,然后使用指向核心转储的 jstackjmap 将其转换为 Java 格式。

关于java - GC开销限制异常: Unable to take threads & heap dump,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44715343/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com