V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
The Go Programming Language
http://golang.org/
Go Playground
Go Projects
Revel Web Framework
xing393939
V2EX  ›  Go 编程语言

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

  •  
  •   xing393939 ·
    xing393939 · 2022-12-06 18:40:58 +08:00 · 1049 次点击
    这是一个创建于 719 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

    lysS
        1
    lysS  
       2022-12-07 12:28:59 +08:00
    runtime.Stack 啊,Frame 可以有更多选项
    xing393939
        2
    xing393939  
    OP
       2022-12-07 16:33:39 +08:00
    @lysS runtime.Stack 打印的是上游调用,我想看它的下游调用
    lysS
        3
    lysS  
       2022-12-08 16:32:59 +08:00
    这个不能静态实现吧? pprof 那个看起来比较靠谱,callvis 就算了吧
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3249 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 00:47 · PVG 08:47 · LAX 16:47 · JFK 19:47
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.