日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

g-gdb调试core文件

發(fā)布時(shí)間:2023/11/27 生活经验 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 g-gdb调试core文件 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

文章目錄

        • core文件
        • 判讀是否為core文件
        • 打開系統(tǒng) core dump
        • 修改core文件的保存路徑
        • gdb調(diào)試core文件

最近初步了解了一下core 文件,已經(jīng)如何將gdb工具與core文件結(jié)合調(diào)試出現(xiàn)段錯(cuò)誤的程序

core文件

core是指操作系的程序統(tǒng)核心。當(dāng)我們的程序在操作系統(tǒng)上運(yùn)行異常崩潰時(shí),操作系統(tǒng)會(huì)將此時(shí)系統(tǒng)內(nèi)存狀態(tài)報(bào)存下來,放入一個(gè)core文件,這個(gè)過程叫做core dump,也即是核心轉(zhuǎn)儲(chǔ)。該過程可以理解為操作系統(tǒng)對(duì)內(nèi)存的快照,保存的內(nèi)容除了基本內(nèi)存信息之外還包括寄存器信息(程序指針,棧指針),內(nèi)存管理信息,程序運(yùn)行狀態(tài)信息等。core文件能夠快速幫助開發(fā)者定位出很難發(fā)現(xiàn)的程序異常問題。

判讀是否為core文件

一般core文件是以core開頭的,

  • 使用命令readelf讀取存儲(chǔ)該文件的的elf加載表頭信息,其中包含core file的信息
    readelf -h /tmp/core-hcli-17503-1556000117
    ELF Header:Magic:   7f 45 4c 46 02 01 01 00 00 00 00 00 00 00 00 00 Class:                             ELF64
    Data:                              2's complement, little endian
    Version:                           1 (current)
    OS/ABI:                            UNIX - System V
    ABI Version:                       0
    Type:                              CORE (Core file)  #文件類型為core文件
    Machine:                           Advanced Micro Devices X86-64
    Version:                           0x1
    Entry point address:               0x0
    Start of program headers:          64 (bytes into file)
    Start of section headers:          0 (bytes into file)
    Flags:                             0x0
    Size of this header:               64 (bytes)
    Size of program headers:           56 (bytes)
    Number of program headers:         112
    Size of section headers:           0 (bytes)
    Number of section headers:         0
    Section header string table index: 0
    
  • 使用file命令也可以看到core屬性
    file /tmp/core-hcli-17503-1556000117 |grep core
    /tmp/core-hcli-17503-1556000117: ELF 64-bit LSB core file x86-64, version 1 (SYSV), SVR4-style, from '/b_iscsi/bn_cli/hcli ceph disk add --name ceph -s abcdef -l 10.192.55.180 INTEL'
    

打開系統(tǒng) core dump

使用命令ulimit -c [blocks]

  • ulimit -c查看當(dāng)前系統(tǒng)core文件的大小限制

    [root@node1 ~]# ulimit -c0 
    

    這個(gè)時(shí)候操作系統(tǒng)的core dump是關(guān)閉的,此時(shí)如果當(dāng)前系統(tǒng)程序異常終止也不會(huì)生成core文件

  • ulimit -c 1024 限制當(dāng)前系統(tǒng)的core文件大小為1024(blocks),記住這里的blocks為操作系統(tǒng)塊大小,一般默認(rèn)為512B,即這里限制core文件大小不超過1024 * 512 B

  • ulimit -c unlimited 對(duì)操作系統(tǒng)生成的core文件大小不做限制

  • 使用以上命令打開core dump只會(huì)對(duì)當(dāng)前終端有效,如果想要永久生效,需要更改core dump配置文件如下:
    vim /etc/security/limits.conf
    增加如下內(nèi)容

    #Each line describes a limit for a user in the form:
    #
    #<domain>        <type>  <item>  <value>
    #
    #下面一行位置為我增加的
    #第一列<domain>為用戶限制
    #第二列<type>為修改限制的類型是軟件還是硬件,這里因?yàn)槭莾?nèi)核相關(guān)文件,則是soft
    #第三列<item>為文件屬性
    #第四列<value>對(duì)屬性具體限制的數(shù)值
    *               soft    core         unlimited
    

    使以上配置文件生效需確保PAM認(rèn)證配置文件中添加pam_limits.so庫(kù),同時(shí)sshd的登錄服務(wù)配置中PAM模塊狀態(tài)為啟用USEPAM yes

    #確保ssh服務(wù)啟動(dòng)是會(huì)加載PAM認(rèn)證模塊
    cat /etc/ssh/sshd_config|grep UsePAM
    UsePAM yes
    

    同時(shí)在如下配置文件中加入PAM的limits庫(kù)

    #在centos下該庫(kù)是在lib64目錄下,如果該配置中存在加載該庫(kù)的語句則不用添加
    vim /etc/pam.d/login
    session    required     /lib64/security/pam_limits.so
    

    以上配置正常的話只需要重新登錄一下終端,/etc/security/limits.conf中的修改即可生效,我們?cè)?code>ulimit -c中可以看到更改過的結(jié)果,且該結(jié)果對(duì)任何登錄終端都生效。

修改core文件的保存路徑

  • 默認(rèn)生成的core文件保存在可執(zhí)行文件路徑下,文件名即為core
  • 通過修改/proc/sys/kernel/core_uses_pid文件讓core文件名自動(dòng)加上進(jìn)程的pid號(hào)變?yōu)?code>core.pid
    執(zhí)行echo 1 > /proc/sys/kernel/core_uses_pid
  • 修改/proc/sys/kernel/core_pattern修改core文件的文件名和生成路徑
    執(zhí)行命令echo "/tmp/core-%e-%p-%t" > /proc/sys/kernel/core_pattern則將生成的core文件目錄放在/tmp目錄下,同時(shí)文件名為core-命令名-pid-時(shí)間
    #如下文件
    /tmp/core-ceph_osd_daemon-10089-1556277405
    /tmp/core-ceph_osd_daemon-13233-1556352109
    /tmp/core-ceph_osd_daemon-14787-1556276292
    /tmp/core-ceph_osd_daemon-17754-1556275923
    

gdb調(diào)試core文件

  • 使用gdb 可執(zhí)行文件絕對(duì)路徑 core文件路徑進(jìn)行調(diào)試,如下
    gdb /root/ceph_osd_daemon /tmp/core-ceph_osd_daemon-22685-1556352590
    進(jìn)入調(diào)試終端,輸入bt即可打印程序異常的函數(shù)調(diào)用棧,使用list + 異常函數(shù)或者list + 代碼行號(hào)查看出錯(cuò)源碼位置,如果還想要繼續(xù)進(jìn)行代碼斷點(diǎn)以及變量跟蹤,則可以進(jìn)一步調(diào)試。使用gdb 可執(zhí)行文件絕對(duì)路徑,進(jìn)行b line設(shè)置斷點(diǎn)進(jìn)行單步調(diào)試
    [root@node1 ~]# gdb /root/ceph_osd_daemon /tmp/core-ceph_osd_daemon-22685-1556352590
    GNU gdb (GDB) Red Hat Enterprise Linux 7.6.1-51.el7
    Copyright (C) 2013 Free Software Foundation, Inc.
    License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
    This is free software: you are free to change and redistribute it.
    There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
    and "show warranty" for details.
    This GDB was configured as "x86_64-redhat-linux-gnu".
    For bug reporting instructions, please see:
    <http://www.gnu.org/software/gdb/bugs/>...
    Reading symbols from /root/ceph_osd_daemon...done.
    [New LWP 22685]
    Core was generated by `/root/ceph_osd_daemon'.
    Program terminated with signal 11, Segmentation fault.
    #0  0x00007f086dadd76b in __strcmp_sse42 () from /lib64/libc.so.6
    #我這里系統(tǒng)的libc庫(kù)版本較低,所以debuginfo要求需要安裝高版本C庫(kù)即可
    Missing separate debuginfos, use: debuginfo-install glibc-2.17-222.el7.x86_64
    (gdb) bt #查看函數(shù)調(diào)用棧
    #0  0x00007f086dadd76b in __strcmp_sse42 () from /lib64/libc.so.6
    #1  0x00000000004041f3 in get_min_value (buff=0x7fffaa8fe700 "14 2", p_infos_a=0x7fffaa8fe300) at ceph_osd_daemon.c:970
    #2  0x000000000040464c in get_max_out_num (osds=0x7fffaa8fea90) at ceph_osd_daemon.c:1033
    #3  0x0000000000404e97 in ceph_daemon_exec () at ceph_osd_daemon.c:1180
    #4  0x000000000040501b in main (argc=1, argv=0x7fffaa902db8) at ceph_osd_daemon.c:1221
    (gdb) list 970 #查看出錯(cuò)的源代碼位置
    965             for (i=0; NULL != p_infos_a[i]; i++){
    966             //for (i=0; i < pool_flag - 1 && NULL != p_infos_a[i]; i++){
    967             //for (i=0; i < pool_flag && strlen(p_infos_a[i]); i++){
    968             //printf("<fldb> line:%d\n",__LINE__);
    969             printf("<fldb> i:%d\n",i);
    970                 if (!strcmp(p_infos_a[i]->pool_id,tmp_id)) {
    971                     strcpy(p_infos_a[i]->min_size,tmp_redu);
    972                     }
    973             }
    974             return;
    

總結(jié)

以上是生活随笔為你收集整理的g-gdb调试core文件的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。