如何可视化堆转储?

Iht*_*kaS 8 debugging garbage-collection go heap-dump

我们使用 golang 开发了一个服务器,它将接收并发请求并处理请求(创建大对象 - 一棵树),然后发回回复。但是对象不是垃圾收集的。所以我决定分析生活在内存中的对象。首先,我写了一个简单的程序

package main

import (
    "fmt"
    "io/ioutil"
    "os"
    "runtime/debug"
)

func main() {
    var i_am_a int = 10
    _ = i_am_a
    func() {
        f, err := os.Create("dump")
        defer f.Close()
        if err != nil {
            panic(err)
        }
        debug.WriteHeapDump(f.Fd())
    }()

    b, err := ioutil.ReadFile("dump")
    if err != nil {
        panic(err)
    }
    fmt.Print(string(b))

}
Run Code Online (Sandbox Code Playgroud)

但我无法理解代表(https://github.com/golang/go/wiki/heapdump13 - 这没有帮助)。我想要的只是从内存(大对象)追溯到保存对象根地址的地方(go app 代码中的变量)。这样我就可以释放引用并让 GC 在它的循环中收集它。是否有最新的工具来可视化 heapdump?或者有没有更好的方法来解决这个问题?

Bry*_*yan 3

目前,您的问题没有完整的解决方案。最新的堆转储格式解释了运行时不再跟踪以前可用的一些信息。

Go Issue 16410有大量有关正在进行的工作的详细信息和信息。

goheapdump是一个可能有帮助的工具(一项正在进行的工作)