V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
xing393939

可以方便打印某个函数下的函数调用链路的工具?

  •  
  •   xing393939 ·
    xing393939 · Dec 6, 2022 · 1484 views
    This topic created in 1250 days ago, the information mentioned may be changed or developed.

    就像这篇文章介绍的,打印 main 函数的调用链路,最终结果如下:

    g[01]:  ->main.A1
    g[01]:      ->main.B1
    g[01]:          ->main.C1
    g[01]:              ->main.D
    

    目前知道有go-callvis,但是它是基于静态代码分析的,所以得到的结果会很杂乱。而上面说的那种方法,需要用代码生成工具给每个函数插入一行 defer 代码。有没有非侵入式的办法?个人感觉用 ebpf 是可以实现的。

    lysS
        1
    lysS  
       Dec 7, 2022
    runtime.Stack 啊,Frame 可以有更多选项
    xing393939
        2
    xing393939  
    OP
       Dec 7, 2022
    @lysS runtime.Stack 打印的是上游调用,我想看它的下游调用
    lysS
        3
    lysS  
       Dec 8, 2022
    这个不能静态实现吧? pprof 那个看起来比较靠谱,callvis 就算了吧
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   3021 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 13:34 · PVG 21:34 · LAX 06:34 · JFK 09:34
    ♥ Do have faith in what you're doing.