下面說明一下 linux 下調(diào)試 core dump 方法。
dmesg+addr2line調(diào)試
先介紹 2 個 linux 命令:
dmesg ,一種程序,用于檢測和控制內(nèi)核緩沖。程序用來幫助用戶,了解系統(tǒng)的啟動信息,可以獲得出錯堆棧地址。
addr2line ,可以將指令的地址和可執(zhí)行映像轉(zhuǎn)換成文件名,函數(shù)名或源代碼的工具。這種功能將跟蹤地址轉(zhuǎn)換成更有意義的內(nèi)容來說很有用。
在調(diào)用 addr2line 工具時,要使用 -e 選項來指定可執(zhí)行映像,使用 -f 選項可以告訴工具輸出函數(shù)名。
linux下操作過程:
[root@VM-16-9-centos c++]# dmesg | grep a.out
[ 212.330289] a.out[1946]: segfault at 0 ip 0000000000400571 sp 00007ffdf0aafbb0 error 6 in a.out[400000+1000]
[ 227.437065] a.out[1989]: segfault at 0 ip 0000000000400571 sp 00007ffcfd01c8c0 error 6 in a.out[400000+1000]
[root@VM-16-9-centos c++]#
[root@VM-16-9-centos c++]# addr2line -e a.out 0000000000400571
/root/c++/main.cpp:6
先通過dmesg找到對應(yīng)出錯的地址,再用 addr2line -e 將地址解析到對應(yīng)的代碼行。
gdb調(diào)試
gdb 想必大家都有聽說,Linux 下面一款常用的的調(diào)試工具。
gdb 編譯器通常以 gdb 命令的形式在終端中使用,下面學(xué)習(xí)下常用調(diào)試選項。
bt :查看堆棧信息
i locals :查看當(dāng)前程序棧的局部變量
i args :查看當(dāng)前程序棧的參數(shù)
i catch :查看當(dāng)前程序中棧幀的異常處理器
p a :打印變量的值
i register :查看當(dāng)前寄存器的值
r :從運行程序至第一個斷點,沒有斷點則一直運行完
quit :退出
gdb調(diào)試過程中,輸入 r ,bt。r 是運行 a.out 文件,bt查看堆棧情況。
我們不需要執(zhí)行 gdb a.out,這樣就相當(dāng)于重新運行了 a.out 文件。然而在實際開發(fā)中,有很多問題都是概率發(fā)生的,所以此方法不太實用。
linux下操作過程(省略部分 gdb 介紹信息):
[root@VM-16-9-centos c++]# gdb a.out core.1989
Reading symbols from /root/c++/a.out...done.
[New LWP 1989]
bCore was generated by `./a.out'.
Program terminated with signal 11, Segmentation fault.
#0 0x0000000000400571 in main () at main.cpp:6
6 *p=0;
Missing separate debuginfos, use: debuginfo-install glibc-2.17-307.el7.1.x86_64 libgcc-4.8.5-44.el7.x86_64 libstdc++-4.8.5-44.el7.x86_64
(gdb) bt
#0 0x0000000000400571 in main () at main.cpp:6
(gdb)
直接執(zhí)行 gdb a.out core.1989,不用 r 命令避免程序重復(fù)執(zhí)行。使用 bt 命令,可以看到程序出錯代碼行。
strace+addr2line調(diào)試
strace 是一個集診斷、調(diào)試、統(tǒng)計與一體的工具,我們可以使用strace,對應(yīng)用的系統(tǒng)調(diào)用和信號傳遞的跟蹤結(jié)果,來對應(yīng)用進行分析,以達到解決問題,或者是了解應(yīng)用工作過程的目的。
strace 的簡單的用法就是,執(zhí)行一個指定的命令,在指定的命令結(jié)束之后,它也就退出了。
在命令執(zhí)行的過程中,strace 會記錄和解析命令進程的所有系統(tǒng)調(diào)用,以及這個進程所接收到的,所有的信號值。
-c ,統(tǒng)計每一系統(tǒng)調(diào)用的所執(zhí)行的時間,次數(shù)和出錯的次數(shù)等
-p ,指定進程pid
-i ,輸出系統(tǒng)調(diào)用的入口指針
linux 下操作過程(省略部分加載信息):
[root@VM-16-9-centos c++]# strace -i ./a.out
[00007f79d3573847] munmap(0x7f79d3772000, 31038) = 0
[0000000000400571] --- SIGSEGV {si_signo=SIGSEGV, si_code=SEGV_MAPERR, si_addr=NULL} ---
[????????????????] +++ killed by SIGSEGV (core dumped) +++
Segmentation fault
[root@VM-16-9-centos c++]# addr2line -e a.out 0000000000400571
/root/c++/main.cpp:6
-
Linux
+關(guān)注
關(guān)注
87文章
11351瀏覽量
210510 -
調(diào)試
+關(guān)注
關(guān)注
7文章
589瀏覽量
34082 -
程序
+關(guān)注
關(guān)注
117文章
3798瀏覽量
81461 -
系統(tǒng)
+關(guān)注
關(guān)注
1文章
1020瀏覽量
21441
發(fā)布評論請先 登錄
相關(guān)推薦
ESP32_MINI燒錄程序后遇到esp_core_dump_flash問題怎么解決?
關(guān)于系統(tǒng)應(yīng)用core dump的分析
你知道Linux Core Dump是什么?
學(xué)會用core dump調(diào)試程序錯誤
![學(xué)會用<b class='flag-5'>core</b> <b class='flag-5'>dump</b><b class='flag-5'>調(diào)試</b>程序錯誤](https://file.elecfans.com/web1/M00/92/57/pIYBAFzdItmARFSlAAAcmaqFX_w453.png)
段錯誤調(diào)試神器 - Core Dump詳解
linux中的core dump調(diào)試與運用詳解
使用 VSCode 遠程 圖形化 GDB 調(diào)試 嵌入式linux
![使用 VSCode 遠程 圖形化 GDB <b class='flag-5'>調(diào)試</b> 嵌入式<b class='flag-5'>linux</b>](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
嵌入式Linux如何生成Core Dump文件
![嵌入式<b class='flag-5'>Linux</b>如何生成<b class='flag-5'>Core</b> <b class='flag-5'>Dump</b>文件](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
Core 1808 JD4資源linux header/linux image
![<b class='flag-5'>Core</b> 1808 JD4資源<b class='flag-5'>linux</b> header/<b class='flag-5'>linux</b> image](https://file.elecfans.com/web1/M00/D9/4E/pIYBAF_1ac2Ac0EEAABDkS1IP1s689.png)
評論