本文主要是介绍linux下使用googlebreakpad解析dmp文件获取堆栈,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1.下载google-breakpad源码
git clone https://chromium.googlesource.com/breakpad/breakpad
2.配置
./configure
3.编译
make
4.进入src/processor目录,拷贝想要解析的dmp文件到该目录
5.输出结果(不带符号表)
执行script -f output.txt
(ubuntu将屏显输出到文件)
再执行./minidump_stackwalk xxx.dmp
结果便存储到output.txt中了
6.带符号表解析
windows中使用dump_syms.exe(可去官网下载)产生sym符号表文件。在cmd中运行:
dump_syms test.pdb > test.sym
得到test.sym符号表文件,用文本编辑打开该文件,第一行为:
MODULE windows x86_64 530B0CABE8E149C2A831A8C676B4B0641 test.pdb
回到linux环境,在src/processor目录创建符号表目录symDir,再创建文件夹530B0CABE8E149C2A831A8C676B4B0641 ,再将test.sym放到该文件夹中
符号表目录结构为:
如果有多个符号文件,可以在symDir中按相同格式继续放置test1.pdb、test2.pdb~
然后执行:
./minidump_stackwalk xxx.dump symDir
可在output.txt解析中看到带文件行数,函数名的堆栈解析结果
这篇关于linux下使用googlebreakpad解析dmp文件获取堆栈的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!