gpt4 book ai didi

java - 分析 Java 服务器并解释火焰图

转载 作者:行者123 更新时间:2023-12-02 10:53:04 33 4
gpt4 key购买 nike

我正在分析 java 服务器。我正在查看火焰图:http://www.brendangregg.com/flamegraphs.html 。我有几个关于如何解释火焰轮廓的问题。我是 java 新手,所以它们听起来可能非常基础。

1) 在配置文件中,我观察到 libjvm_so 的顶部框架占用了 38.6% 的 cpu。这在java进程和服务器中正常吗?这个共享对象到底是什么?它通常需要如此多的处理吗?

2) 函数/堆栈取 x% 意味着什么。这是相对的还是绝对的?进程总 cpu 使用率的 x% 或 x% cpu。这引出了我的第二个问题,当我比较 2 个火焰图时,比较是否通过进程的所有 cpu 使用情况进行标准化?也就是说,如果一个方法在一个配置文件中占用 10%,而在另一个配置文件中占用 15%,这是否意味着该函数实际上消耗了更多 cpu。或者可能是这样的情况:初始进程的总体 cpu 使用率为 50%,但在第二个进程中,cpu 使用率为 30%,因此从绝对值来看,第二个配置文件显示该函数的 cpu 使用率有所下降。 (50% 的 10% 大于 30% 的 15%)。

最佳答案

对于问题 1:

我认为 libjvm.so 包括编译和垃圾收集所花费的时间。如果进程的 CPU 利用率很高并且该进程已经运行了一段时间,则在 libjvm.so 中花费大量 CPU 时间通常可能不是预期的,因此可能表明进程在 GC 或编译上花费的时间比预期多。如果在进程启动时收集配置文件(因此需要更多时间用于编译),这可能是预期的。

对于问题 2:

火焰图中的百分比通常是指进程使用的CPU总量的百分比。因此,如果配置文件显示总共 5 秒的 CPU 时间,则使用 1 秒 CPU 时间的方法将显示为使用了所有已用 CPU 时间的 20%。

Stackdriver Profiler 收集的 CPU 配置文件在 10 秒的时间内收集,可用于了解进程使用的 CPU 百分比。例如,当进程使用约 50% 的 CPU 时,会收集总共 5 秒的配置文件。

对于 Stackdriver Profiler 中的配置文件比较,火焰图根据两个配置文件中 CPU 使用率之间的绝对差异进行着色。工具提示中报告了绝对差异和占总数百分比的差异。

记录了火焰图的高级概述here

(披露:我在 Google 从事 Stackdriver Profiler 工作)

关于java - 分析 Java 服务器并解释火焰图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52014377/

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