在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

linux中的core dump調試與運用詳解

Linux愛好者 ? 來源:CSDN技術社區 ? 作者:晨夢思雨 ? 2021-04-12 14:24 ? 次閱讀

緣起

調試,是開發流程中一個非常重要的環節。每個程序員都應,具備調試代碼的能力,尤其對于從事 Linux 下的開發的讀者。

從事 linux 下后臺開發,有時候會遇到程序突然崩潰的情況,也沒有任何日志,這會讓你不知所措。

今天給大家介紹一個 core 文件,用這個文件,我們可以找出對應出錯的代碼行,感覺是不是很神奇。

透著樹蔭看著朦朧的太陽,曬著日光浴,感覺還不錯。先學完這篇,我們再去欣賞風景。

什么是core dump

對于程序,由于各種異常或者 bug,導致在運行過程中,并且在滿足一定條件下,產生一個叫做 core 的文件。

通常情況下,core 文件會包含了,程序運行時的內存,寄存器狀態,堆棧指針,內存管理信息還有各種函數調用堆棧信息等。

許多程序出錯的時候,會產生一個 core 文件。通過工具分析這個文件,我們可以定位到,程序異常退出的時候對應的堆棧調用等信息。

打開 core dump 開關:ulimit -c unlimited

看一段有問題的代碼:

#include《stdio.h》

int main()

{

int *p=NULL;

*p=0;

printf(“bad

”);

return 0;

}

linux下編譯和執行:

[root@VM-16-9-centos c++]# g++ -g main.cpp

[root@VM-16-9-centos c++]# 。/a.out

Segmentation fault (core dumped)

[root@VM-16-9-centos c++]# ls

a.out core.1989 main.cpp

上述代碼一看就有錯誤,執行會產生 core dump。但是在大型項目中,用肉眼就很難看了。下面說明一下 linux 下調試 core dump 方法。

dmesg+addr2line調試

先介紹 2 個 linux 命令:

dmesg ,一種程序,用于檢測和控制內核緩沖。程序用來幫助用戶,了解系統的啟動信息,可以獲得出錯堆棧地址。

addr2line ,可以將指令的地址和可執行映像轉換成文件名,函數名或源代碼的工具。這種功能將跟蹤地址轉換成更有意義的內容來說很有用。

在調用 addr2line 工具時,要使用 -e 選項來指定可執行映像,使用 -f 選項可以告訴工具輸出函數名。

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找到對應出錯的地址,再用 addr2line -e 將地址解析到對應的代碼行。

gdb調試

gdb 想必大家都有聽說,Linux 下面一款常用的的調試工具。

gdb 編譯器通常以 gdb 命令的形式在終端中使用,下面學習下常用調試選項。

bt :查看堆棧信息

i locals :查看當前程序棧的局部變量

i args :查看當前程序棧的參數

i catch :查看當前程序中棧幀的異常處理器

p a :打印變量的值

i register :查看當前寄存器的值

r :從運行程序至第一個斷點,沒有斷點則一直運行完

quit :退出

gdb調試過程中,輸入 r ,bt。r 是運行 a.out 文件,bt查看堆棧情況。

我們不需要執行 gdb a.out,這樣就相當于重新運行了 a.out 文件。然而在實際開發中,有很多問題都是概率發生的,所以此方法不太實用。

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)

直接執行 gdb a.out core.1989,不用 r 命令避免程序重復執行。使用 bt 命令,可以看到程序出錯代碼行。

strace+addr2line調試

strace 是一個集診斷、調試、統計與一體的工具,我們可以使用strace,對應用的系統調用和信號傳遞的跟蹤結果,來對應用進行分析,以達到解決問題,或者是了解應用工作過程的目的。

strace 的簡單的用法就是,執行一個指定的命令,在指定的命令結束之后,它也就退出了。

在命令執行的過程中,strace 會記錄和解析命令進程的所有系統調用,以及這個進程所接收到的,所有的信號值。

-c ,統計每一系統調用的所執行的時間,次數和出錯的次數等

-p ,指定進程pid

-i ,輸出系統調用的入口指針

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 調試技巧很重要,平時用到的也會很多,掌握好這些很關鍵。通過這篇文章,希望讀者能對 core dump 調試有大致了解。
編輯:lyn

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • Linux
    +關注

    關注

    87

    文章

    11351

    瀏覽量

    210512
  • Core
    +關注

    關注

    0

    文章

    175

    瀏覽量

    43033

原文標題:linux 下調試 core dump 方式匯總,工作必備技能

文章出處:【微信號:LinuxHub,微信公眾號:Linux愛好者】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    解析汽車拋負載Load Dump:load dump產生原因與TVS并聯保護方案

    讓我們聊聊Load Dump 在汽車電子,load dump指的是低壓電池在充電時與車輛的發電機突然斷開連接。由于電池的突然斷開,其余被接在發電機總線上的負載會承受非常大的浪涌電壓。這個浪涌電壓
    的頭像 發表于 01-24 10:43 ?3501次閱讀
    解析汽車拋負載Load <b class='flag-5'>Dump</b>:load <b class='flag-5'>dump</b>產生原因與TVS并聯保護方案

    自鎖電路的調試步驟詳解

    自鎖電路的調試是確保電路按預期工作的關鍵步驟。以下是自鎖電路調試的詳細步驟: 一、準備階段 檢查電路連接 : 仔細檢查電路的所有連接點,確保它們連接牢固、無松動。 檢查所有導線,確保它們沒有破損
    的頭像 發表于 01-18 10:16 ?196次閱讀

    Linux grep命令詳解

    Linux grep命令是一種非常常用的文本搜索工具,它可以在給定的文件搜索匹配的字符串,并輸出匹配的行。grep是全稱“global search regular expression print”,可以識別正則表達式,并使用正則表達式進行搜索。
    的頭像 發表于 12-25 09:39 ?277次閱讀

    嵌入式工程師都在找的【Linux內核調試技術】建議收藏!

    在嵌入式系統的開發Linux內核調試是一個至關重要的環節。 隨著處理器技術的不斷進步和嵌入式領域的蓬勃發展,掌握有效的內核調試技術成為了開發者們的一項必備技能。本文將介紹幾種常見
    發表于 11-28 15:37

    Linux用戶管理詳解

    用戶分為普通用戶和超級用戶,超級用戶在Windows系統為Administrator在Linux系統為root。登陸Linux系統需要提供用戶名與密碼,登陸后通過一定的方法管理該系
    的頭像 發表于 11-01 09:48 ?236次閱讀

    深度解析linux HID核心

    linux內核,HID核心是完成HID功能的關鍵組件,如果內核支持HID,在啟動過程,則會對HID進行初始化,完成該操作的函數是hid_init(),實現在/drivers/hid/hid-
    的頭像 發表于 09-29 17:04 ?653次閱讀
    深度解析<b class='flag-5'>linux</b> HID核心

    linux安裝.net core3.1步驟

    linux安裝.net core3.1步驟 各項用到的命令
    發表于 09-03 11:41 ?0次下載

    詳解Linux的權限控制

    本章將和大家分享Linux的權限控制。廢話不多說,下面我們直接進入主題。
    的頭像 發表于 08-05 15:32 ?672次閱讀
    <b class='flag-5'>詳解</b><b class='flag-5'>Linux</b><b class='flag-5'>中</b>的權限控制

    ESP32_MINI燒錄程序后遇到esp_core_dump_flash問題怎么解決?

    ) esp_core_dump_flash: Core dump flash config is corrupted! CRC=0x7bd5c66f instead of 0x0 Rebooting... ets
    發表于 07-01 06:52

    ESP32-S3上電無法啟動esp_core_dump_flash是怎么回事?

    上電串口打印信息無法啟動,不知道哪里的問題,好心人解答下 ELF file SHA256: 5b8e7b8cba2a208c E (765) esp_core_dump_flash: Core
    發表于 06-28 07:57

    RA MCU CANFD在FSP的配置詳解

    RA MCU CANFD在FSP的配置詳解
    的頭像 發表于 06-19 08:06 ?627次閱讀
    RA MCU CANFD在FSP<b class='flag-5'>中</b>的配置<b class='flag-5'>詳解</b>

    OpenHarmonySELinux使用詳解

    OpenHarmonySELinux使用詳解 目錄 1.SELinux簡介 2.SELinux概念 3.SELinux模式 4.OHSELinux使用詳解 5.OH
    發表于 04-03 10:43

    嵌入式Linux C語言編程程序調試與宏定義

    Linux使用gcc編譯程序的時候,對于調試的語句還具有一些特殊的語法。gcc編譯的過程,會生成一些宏,可以使用這些宏分別打印當前源文件的信息,主要內容是當前的文件、當前運行的函數和當前的程序行。
    發表于 03-01 11:41 ?1134次閱讀

    [廣東龍芯2K1000/2K500開發板]如何利用coredump 進行調試

    如何利用coredump 進行調試 編譯時加入調試信息((PC 機上)) 編譯參數為 -g ?loongarch64-linux-gnu-gcc -g 1.c 開啟core文件
    發表于 02-20 13:05

    TC275調試時斷點設置在core1_main和core2_main為啥就不會停的原因?

    調試時斷點設置在core0_main函數下,會正常的停,設置在core1_main和core2_main為啥就不會停呢,可以確定core1
    發表于 02-18 06:10
    主站蜘蛛池模板: 亚洲一区免费 | 免费国产一区 | 国产黄色小视频在线观看 | 午夜cao| 日本国产中文字幕 | 日韩啪啪电影 | 一级毛片一级毛片 | 欧美一区二区三区性 | 久久这里精品青草免费 | 日本黄色视屏 | 国内亚州视频在线观看 | 久久婷婷一区二区三区 | 成人精品久久 | 久久婷婷久久一区二区三区 | 在线观看你懂的网站 | 欧美色性视频 | 办公室桌震娇喘视频大全在线 | 国产片一级特黄aa的大片 | 午夜影视免费完整高清在线观看网站 | 性无码专区无码 | 国产午夜在线视频 | 亚洲人色大成年网站在线观看 | 国产福利资源 | 美女拍拍拍黄色 | 91极品女神私人尤物在线播放 | 久久精品系列 | 亚洲二区在线观看 | 天天干天天干天天干天天 | 色cccwww| 免费高清视频在线观看 | 国产精品午夜自在在线精品 | 亚洲午夜视频在线 | 久精品视频村上里沙 | 五月天丁香激情 | 一本大道一卡二卡四卡 | 精品女同 | 亚洲专区一 | 亚洲一区在线视频观看 | 网站国产| 欧美特级生活片 | 色草视频 |