簡體   English   中英

Java飛行記錄儀剖析摘要提取

[英]Java flight recorder profiling summary extraction

我希望能夠以文本格式提取通過分析 JFR 記錄檢測到的“熱點”的某種摘要。 確切地說,我想提取運行某些特定功能或某些特定 class 產生的熱點。 像這樣的東西:

<some tool> myfile.jfr --look-at-class='org/me/MyClass' --limit 10 --order-by self-time

並獲取從org.me中的MyClass調用的最耗時的 10 個方法方法表。 我嘗試查看jfr命令行工具,但它沒有這樣的功能。 或者,江鈴只有圖形界面,沒有命令行界面。 還有其他方法可以獲得這樣的結果嗎?

使用JFR Parsing API創建這樣的工具很容易。

import jdk.jfr.consumer.RecordingFile;

import java.nio.file.Paths;
import java.util.HashMap;

public class JfrTop {

    public static void main(String[] args) throws Exception {
        var fileName = args[0];
        var packageName = args.length > 1 ? args[1] : "";
        var top = args.length > 2 ? Integer.parseInt(args[2]) : 10;

        var hotMethods = new HashMap<String, Long>();
        long total = 0;

        try (var recording = new RecordingFile(Paths.get(fileName))) {
            while (recording.hasMoreEvents()) {
                var event = recording.readEvent();
                if (event.getEventType().getName().equals("jdk.ExecutionSample")) {
                    var stackTrace = event.getStackTrace();
                    if (stackTrace != null && stackTrace.getFrames().size() > 0) {
                        var method = stackTrace.getFrames().get(0).getMethod();
                        var className = method.getType().getName();
                        if (className.startsWith(packageName)) {
                            var fullName = className + '.' + method.getName() + method.getDescriptor();
                            hotMethods.compute(fullName, (key, val) -> val == null ? 1L : (val + 1));
                        }
                    }
                    total++;
                }
            }
        }

        double percent = 100.0 / total;
        hotMethods.entrySet().stream()
                .sorted((e1, e2) -> Long.compare(e2.getValue(), e1.getValue()))
                .limit(top)
                .forEachOrdered(e -> System.out.printf("%5.2f%% %s\n", e.getValue() * percent, e.getKey()));
    }
}

如何運行:

java JfrTop idea.jfr com.intellij.openapi.editor 10

樣品 output:

20,35% com.intellij.openapi.editor.impl.RangeHighlighterTree$RHNode.recalculateRenderFlags()V
 4,20% com.intellij.openapi.editor.impl.IntervalTreeImpl.maxEndOf(Lcom/intellij/openapi/editor/impl/IntervalTreeImpl$IntervalNode;I)I
 3,19% com.intellij.openapi.editor.impl.IntervalTreeImpl.assertAllDeltasAreNull(Lcom/intellij/openapi/editor/impl/IntervalTreeImpl$IntervalNode;)V
 2,19% com.intellij.openapi.editor.impl.IntervalTreeImpl$IntervalNode.computeDeltaUpToRoot()I
 1,94% com.intellij.openapi.editor.impl.IntervalTreeImpl.pushDelta(Lcom/intellij/openapi/editor/impl/IntervalTreeImpl$IntervalNode;)Z
 1,63% com.intellij.openapi.editor.impl.IntervalTreeImpl$IntervalNode.hasAliveKey(Z)Z
 1,50% com.intellij.openapi.editor.impl.IntervalTreeImpl.correctMax(Lcom/intellij/openapi/editor/impl/IntervalTreeImpl$IntervalNode;I)V
 1,31% com.intellij.openapi.editor.impl.IntervalTreeImpl$1.hasNext()Z
 0,88% com.intellij.openapi.editor.impl.IntervalTreeImpl$IntervalNode.tryToSetCachedValues(IZI)Z
 0,63% com.intellij.openapi.editor.impl.IntervalTreeImpl.findOrInsert(Lcom/intellij/openapi/editor/impl/IntervalTreeImpl$IntervalNode;)Lcom/intellij/openapi/editor/impl/IntervalTreeImpl$IntervalNode;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM