gpt4 book ai didi

debugging - 如何可视化堆转储?

转载 作者:IT王子 更新时间:2023-10-29 00:48:01 26 4
gpt4 key购买 nike

我们使用 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))

}

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

最佳答案

目前,您的问题没有完整的解决方案。 newest heap dump format解释了运行时不再跟踪以前可用的一些信息。

Go Issue 16410有很多关于正在进行的工作的细节和信息。

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

关于debugging - 如何可视化堆转储?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41542775/

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