gpt4 book ai didi

java - HotSpot Serviceability Agent 的 iterateObjectsOfKlass() 太慢

转载 作者:行者123 更新时间:2023-11-29 06:53:40 26 4
gpt4 key购买 nike

我可以调用 ObjectHeap.iterateObjectsOfKlass (借助SA)获取属于某个类的所有对象。结果完全符合我的预期,但性能却并非如此。

我花了 >800 秒才得到我的结果,在此期间目标 VM 被挂起。目标 VM 堆大约为 2GB。我知道 iterateObjectsOfKlass 会调用 iterateExact

我的问题是:这些方法是否只是为了获取 1 个类的对象而迭代/遍历整个堆?我很失望,因为我的期望是对于单个类,结果应该在 10 秒内返回秒。

最佳答案

HotSpot Serviceability Agent 是一项非常强大的技术,但确实非常慢。我已经在 this answer 中解释了它是如何工作的.

JVM 没有办法快速找到特定类的所有实例。所以,是的,它必须扫描整个堆。此外,为了读取外部进程的内存,SA 使用 ptrace系统调用每个数据字。这就是为什么它这么慢。

您有几个选项可以更快地扫描堆:

  1. 创建外部进程的核心转储,然后针对核心转储运行 SA 工具。这比读取挂起进程的内存要快得多。查看related question .
  2. 注入(inject) JVMTI使用 Dynamic Attach mechanism 代理进入正在运行的进程.代理可以使用 IterateOverInstancesOfClass 扫描本地 JVM 的堆功能。与 SA 相比,这将快得多,因为它只是从同一进程中读取,而无需任何系统调用或其他任何东西。我相信 2GB 堆只需要几秒钟。

关于java - HotSpot Serviceability Agent 的 iterateObjectsOfKlass() 太慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39474097/

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