91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

linux中的core dump調(diào)試與運(yùn)用詳解

Linux愛(ài)好者 ? 來(lái)源:CSDN技術(shù)社區(qū) ? 作者:晨夢(mèng)思雨 ? 2021-04-12 14:24 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

緣起

調(diào)試,是開(kāi)發(fā)流程中一個(gè)非常重要的環(huán)節(jié)。每個(gè)程序員都應(yīng),具備調(diào)試代碼的能力,尤其對(duì)于從事 Linux 下的開(kāi)發(fā)的讀者。

從事 linux 下后臺(tái)開(kāi)發(fā),有時(shí)候會(huì)遇到程序突然崩潰的情況,也沒(méi)有任何日志,這會(huì)讓你不知所措。

今天給大家介紹一個(gè) core 文件,用這個(gè)文件,我們可以找出對(duì)應(yīng)出錯(cuò)的代碼行,感覺(jué)是不是很神奇。

透著樹(shù)蔭看著朦朧的太陽(yáng),曬著日光浴,感覺(jué)還不錯(cuò)。先學(xué)完這篇,我們?cè)偃バ蕾p風(fēng)景。

什么是core dump

對(duì)于程序,由于各種異?;蛘?bug,導(dǎo)致在運(yùn)行過(guò)程中,并且在滿足一定條件下,產(chǎn)生一個(gè)叫做 core 的文件。

通常情況下,core 文件會(huì)包含了,程序運(yùn)行時(shí)的內(nèi)存,寄存器狀態(tài),堆棧指針,內(nèi)存管理信息還有各種函數(shù)調(diào)用堆棧信息等。

許多程序出錯(cuò)的時(shí)候,會(huì)產(chǎn)生一個(gè) core 文件。通過(guò)工具分析這個(gè)文件,我們可以定位到,程序異常退出的時(shí)候?qū)?yīng)的堆棧調(diào)用等信息。

打開(kāi) core dump 開(kāi)關(guān):ulimit -c unlimited

看一段有問(wèn)題的代碼:

#include《stdio.h》

int main()

{

int *p=NULL;

*p=0;

printf(“bad

”);

return 0;

}

linux下編譯和執(zhí)行:

[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

上述代碼一看就有錯(cuò)誤,執(zhí)行會(huì)產(chǎn)生 core dump。但是在大型項(xiàng)目中,用肉眼就很難看了。下面說(shuō)明一下 linux 下調(diào)試 core dump 方法。

dmesg+addr2line調(diào)試

先介紹 2 個(gè) linux 命令:

dmesg ,一種程序,用于檢測(cè)和控制內(nèi)核緩沖。程序用來(lái)幫助用戶,了解系統(tǒng)的啟動(dòng)信息,可以獲得出錯(cuò)堆棧地址。

addr2line ,可以將指令的地址和可執(zhí)行映像轉(zhuǎn)換成文件名,函數(shù)名或源代碼的工具。這種功能將跟蹤地址轉(zhuǎn)換成更有意義的內(nèi)容來(lái)說(shuō)很有用。

在調(diào)用 addr2line 工具時(shí),要使用 -e 選項(xiàng)來(lái)指定可執(zhí)行映像,使用 -f 選項(xiàng)可以告訴工具輸出函數(shù)名。

linux下操作過(guò)程:

[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

先通過(guò)dmesg找到對(duì)應(yīng)出錯(cuò)的地址,再用 addr2line -e 將地址解析到對(duì)應(yīng)的代碼行。

gdb調(diào)試

gdb 想必大家都有聽(tīng)說(shuō),Linux 下面一款常用的的調(diào)試工具。

gdb 編譯器通常以 gdb 命令的形式在終端中使用,下面學(xué)習(xí)下常用調(diào)試選項(xiàng)。

bt :查看堆棧信息

i locals :查看當(dāng)前程序棧的局部變量

i args :查看當(dāng)前程序棧的參數(shù)

i catch :查看當(dāng)前程序中棧幀的異常處理器

p a :打印變量的值

i register :查看當(dāng)前寄存器的值

r :從運(yùn)行程序至第一個(gè)斷點(diǎn),沒(méi)有斷點(diǎn)則一直運(yùn)行完

quit :退出

gdb調(diào)試過(guò)程中,輸入 r ,bt。r 是運(yùn)行 a.out 文件,bt查看堆棧情況。

我們不需要執(zhí)行 gdb a.out,這樣就相當(dāng)于重新運(yùn)行了 a.out 文件。然而在實(shí)際開(kāi)發(fā)中,有很多問(wèn)題都是概率發(fā)生的,所以此方法不太實(shí)用。

linux下操作過(guò)程(省略部分 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 命令,可以看到程序出錯(cuò)代碼行。

strace+addr2line調(diào)試

strace 是一個(gè)集診斷、調(diào)試、統(tǒng)計(jì)與一體的工具,我們可以使用strace,對(duì)應(yīng)用的系統(tǒng)調(diào)用和信號(hào)傳遞的跟蹤結(jié)果,來(lái)對(duì)應(yīng)用進(jìn)行分析,以達(dá)到解決問(wèn)題,或者是了解應(yīng)用工作過(guò)程的目的。

strace 的簡(jiǎn)單的用法就是,執(zhí)行一個(gè)指定的命令,在指定的命令結(jié)束之后,它也就退出了。

在命令執(zhí)行的過(guò)程中,strace 會(huì)記錄和解析命令進(jìn)程的所有系統(tǒng)調(diào)用,以及這個(gè)進(jìn)程所接收到的,所有的信號(hào)值。

-c ,統(tǒng)計(jì)每一系統(tǒng)調(diào)用的所執(zhí)行的時(shí)間,次數(shù)和出錯(cuò)的次數(shù)等

-p ,指定進(jìn)程pid

-i ,輸出系統(tǒng)調(diào)用的入口指針

linux 下操作過(guò)程(省略部分加載信息):

[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 調(diào)試技巧很重要,平時(shí)用到的也會(huì)很多,掌握好這些很關(guān)鍵。通過(guò)這篇文章,希望讀者能對(duì) core dump 調(diào)試有大致了解。
編輯:lyn

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    88

    文章

    11764

    瀏覽量

    219099
  • Core
    +關(guān)注

    關(guān)注

    0

    文章

    175

    瀏覽量

    44298

原文標(biāo)題:linux 下調(diào)試 core dump 方式匯總,工作必備技能

文章出處:【微信號(hào):LinuxHub,微信公眾號(hào):Linux愛(ài)好者】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    從“人機(jī)交互”到“數(shù)字預(yù)演”:詳解 HMI、SCADA 與虛擬調(diào)試的閉環(huán)架構(gòu)

    從“人機(jī)交互”到“數(shù)字預(yù)演”:詳解 HMI、SCADA 與虛擬調(diào)試的閉環(huán)架構(gòu)
    的頭像 發(fā)表于 03-05 11:36 ?110次閱讀
    從“人機(jī)交互”到“數(shù)字預(yù)演”:<b class='flag-5'>詳解</b> HMI、SCADA 與虛擬<b class='flag-5'>調(diào)試</b>的閉環(huán)架構(gòu)

    深入RK3588內(nèi)核:rockchip_linux_defconfig的作用與調(diào)試價(jià)值

    在 RK3588 芯片的 Linux 開(kāi)發(fā),有一個(gè)文件始終是開(kāi)發(fā)者繞不開(kāi)的核心 ——kernel/arch/arm64/configs/rockchip_linux_defconfig。無(wú)論是首次
    的頭像 發(fā)表于 02-03 15:56 ?1176次閱讀
    深入RK3588內(nèi)核:rockchip_<b class='flag-5'>linux</b>_defconfig的作用與<b class='flag-5'>調(diào)試</b>價(jià)值

    Linux系統(tǒng)性能調(diào)試工具—strace

    今天給大家分享一個(gè)linux內(nèi)核自帶的調(diào)試工具,該工具可用于查看和定位系統(tǒng)問(wèn)題,進(jìn)程運(yùn)行過(guò)程探索,進(jìn)行進(jìn)程監(jiān)控,對(duì)每個(gè)系統(tǒng)調(diào)用都可以監(jiān)測(cè),有助于我們優(yōu)化系統(tǒng)性能。
    的頭像 發(fā)表于 01-30 17:03 ?1917次閱讀
    <b class='flag-5'>Linux</b>系統(tǒng)性能<b class='flag-5'>調(diào)試</b>工具—strace

    DR1平臺(tái)Linux應(yīng)用開(kāi)發(fā)指南:含GDB調(diào)試、Python及MQTT實(shí)戰(zhàn)

    本文為創(chuàng)龍科技DR1 系列評(píng)估板 Linux 應(yīng)用開(kāi)發(fā)手冊(cè),系統(tǒng)講解開(kāi)發(fā)環(huán)境搭建、GDB 調(diào)試、多類(lèi)型應(yīng)用案例及 MQTT 通信實(shí)現(xiàn)。核心內(nèi)容包括 LinuxSDK 與工具鏈配置、GDB 遠(yuǎn)程調(diào)試
    的頭像 發(fā)表于 01-05 16:48 ?4586次閱讀
    DR1平臺(tái)<b class='flag-5'>Linux</b>應(yīng)用開(kāi)發(fā)指南:含GDB<b class='flag-5'>調(diào)試</b>、Python及MQTT實(shí)戰(zhàn)

    如何在Linux列出USB設(shè)備

    Linux操作系統(tǒng)提供了許多命令來(lái)列出系統(tǒng)連接的USB設(shè)備,這些命令非常有用,無(wú)論是查看已連接設(shè)備的信息,還是進(jìn)行系統(tǒng)調(diào)試。 在本文中,我們將介紹一些常用的命令以及它們的使用方法,幫助大家了解
    發(fā)表于 12-24 08:19

    Linux內(nèi)核日志玩明白了嗎?printk調(diào)試神器全解析

    前言:做Linux驅(qū)動(dòng)開(kāi)發(fā)或內(nèi)核調(diào)試的朋友,一定對(duì)printk不陌生,但你真的會(huì)用它嗎?為什么同樣是調(diào)試RK3588內(nèi)核,別人能精準(zhǔn)捕捉關(guān)鍵錯(cuò)誤,你卻被海量日志淹沒(méi)?今天就帶大家吃透printk
    的頭像 發(fā)表于 12-19 08:32 ?873次閱讀
    <b class='flag-5'>Linux</b>內(nèi)核日志玩明白了嗎?printk<b class='flag-5'>調(diào)試</b>神器全解析

    【迅為工業(yè)RK3568穩(wěn)定可靠】itop-3568開(kāi)發(fā)板Linux驅(qū)動(dòng)開(kāi)發(fā)實(shí)戰(zhàn):RK3568內(nèi)核模塊符號(hào)導(dǎo)出詳解

    【迅為工業(yè)RK3568穩(wěn)定可靠】itop-3568開(kāi)發(fā)板Linux驅(qū)動(dòng)開(kāi)發(fā)實(shí)戰(zhàn):RK3568內(nèi)核模塊符號(hào)導(dǎo)出詳解
    的頭像 發(fā)表于 11-21 13:25 ?1242次閱讀
    【迅為工業(yè)RK3568穩(wěn)定可靠】itop-3568開(kāi)發(fā)板<b class='flag-5'>Linux</b>驅(qū)動(dòng)開(kāi)發(fā)實(shí)戰(zhàn):RK3568內(nèi)核模塊符號(hào)導(dǎo)出<b class='flag-5'>詳解</b>

    ElfBoard技術(shù)貼|如何在【RK3588】ELF 2開(kāi)發(fā)板進(jìn)行GDB調(diào)試

    GDB(GNU Project Debugger)是在Linux環(huán)境下功能全面的調(diào)試工具。它提供了一系列強(qiáng)大的調(diào)試功能,包括設(shè)置斷點(diǎn)、單步執(zhí)行、打印與觀察變量、查看寄存器及堆棧信息等。在Lin
    的頭像 發(fā)表于 11-11 13:47 ?5244次閱讀
    ElfBoard技術(shù)貼|如何在【RK3588】ELF 2開(kāi)發(fā)板進(jìn)行GDB<b class='flag-5'>調(diào)試</b>

    在Windows和Linux環(huán)境下分別使用Olimex和蜂鳥(niǎo)調(diào)試器下載程序

    ://doc.nucleisys.com/hbirdv2/quick_start/sdk.html 的說(shuō)明進(jìn)行操作。 在Linux系統(tǒng)下使用Olimex ARM-USB-TINY-H調(diào)試器時(shí),在完成gcc
    發(fā)表于 10-31 08:26

    Linux基礎(chǔ)命令which詳解

    Linux系統(tǒng),which命令用于查找并顯示指定命令的可執(zhí)行文件路徑。這對(duì)于系統(tǒng)管理員和開(kāi)發(fā)人員來(lái)說(shuō)是一個(gè)非常有用的工具,可以幫助定位命令所在的位置,確認(rèn)命令是否已正確安裝,并且能夠用于配置環(huán)境變量等任務(wù)。下面是華納云對(duì)which命令的詳細(xì)解釋。
    的頭像 發(fā)表于 07-29 17:58 ?866次閱讀

    Linux系統(tǒng)中網(wǎng)絡(luò)配置詳解

    網(wǎng)絡(luò)配置是Linux系統(tǒng)運(yùn)維的核心技能之一。正確理解和配置子網(wǎng)掩碼、網(wǎng)關(guān)等網(wǎng)絡(luò)參數(shù),直接影響系統(tǒng)的網(wǎng)絡(luò)連通性和性能。本文將深入探討Linux系統(tǒng)中網(wǎng)絡(luò)配置的方方面面,為運(yùn)維工程師提供全面的技術(shù)指導(dǎo)。
    的頭像 發(fā)表于 07-17 11:01 ?1216次閱讀

    2.0.0版本的ST Edge AI Corelinux平臺(tái)上可以把量化后的onnx模型轉(zhuǎn)換為.nb,但是運(yùn)行報(bào)錯(cuò),缺少文件,為什么?

    2.0.0版本的ST Edge AI Core工具在linux平臺(tái)上應(yīng)該是可以把量化后的onnx模型轉(zhuǎn)換為.nb,但是運(yùn)行報(bào)錯(cuò),缺少文件。
    發(fā)表于 06-17 06:29

    安徽京準(zhǔn):北斗衛(wèi)星同步時(shí)鐘的安裝與調(diào)試詳解

    安徽京準(zhǔn):北斗衛(wèi)星同步時(shí)鐘的安裝與調(diào)試詳解
    的頭像 發(fā)表于 06-05 10:08 ?1560次閱讀
    安徽京準(zhǔn):北斗衛(wèi)星同步時(shí)鐘的安裝與<b class='flag-5'>調(diào)試</b><b class='flag-5'>詳解</b>

    詳解Linux系統(tǒng)的服務(wù)管理

    Linux,無(wú)論何時(shí)當(dāng)你安裝任何帶有服務(wù)和守護(hù)進(jìn)程的包,系統(tǒng)默認(rèn)會(huì)把這些服務(wù)的初始化及 systemd腳本添加進(jìn)去,不過(guò)此時(shí)它們并沒(méi)有被啟用。
    的頭像 發(fā)表于 05-23 15:10 ?841次閱讀
    <b class='flag-5'>詳解</b><b class='flag-5'>Linux</b>系統(tǒng)<b class='flag-5'>中</b>的服務(wù)管理

    如何使用S32DS在MPC5775B并行運(yùn)行兩個(gè)內(nèi)核(core0 和 core2)?

    誰(shuí)能幫我了解如何使用 S32DS 在 MPC5775B 并行運(yùn)行兩個(gè)內(nèi)核(core0 和 core2)?
    發(fā)表于 03-31 06:27