使用GDB(一):分析core.xxx文件常用方法

一、Linux生成core文件

当进程异常时如段错误退出时会产生core文件,当进程执行某处代码阻塞时,可以强制生成core文件。

1.1 core文件生成大小限制

  • ulimit -c,可查看生成core文件的大小,0表示未开启,unlimited表示无限制。
  • ulimit -c filesize,限制生成core文件的大小,ulimit -c 0表示不开启,ulimit -c 1000表示限制core文件限制为1000KBulimit -c unlimited无限制。

1.2 core文件生成路径

  • 默认路径为当前命令的执行路径,以下命令可查看:
    cat /proc/sys/kernel/core_pattern
    /sbin/sysctl kernel.core_pattern
    
  • 临时修改:修改/proc/sys/kernel/core_pattern文件,echo "/corefile/core" > /proc/sys/kernel/core_pattern可以将core文件统一生成到/corefile目录下。
  • 永久修改:使用sysctl -w name=value命令,/sbin/sysctl -w kernel.core_pattern=/corefile/core
  • 有的机器或docker使用/corefile/core或默认路径无法保存core文件(可能是权限问题?),这时候可以使用系统中已经存在的目录作为core文件生成路径,如/tmp/core

1.3 core文件生成文件名

  • 默认文件名为core,以下命令可查看:
    cat /proc/sys/kernel/core_pattern
    /sbin/sysctl kernel.core_pattern
    
  • 临时修改:修改/proc/sys/kernel/core_pattern文件,echo "core-%p-%e" > /proc/sys/kernel/core_pattern生成core文件名为core-pid-程序文件名
  • 永久修改:使用sysctl -w name=value命令,/sbin/sysctl -w kernel.core_pattern=core-%p-%e
    %p - insert pid into filename 添加pid
    %u - insert current uid into filename 添加当前uid 
    %g - insert current gid into filename 添加当前gid
    %s - insert signal that caused the coredump into the filename 添加导致产生core的信号 
    %t - insert UNIX time that the coredump occurred into filename 添加core文件生成时的unix时间(197011日计起的秒数)
    %h - insert hostname where the coredump happened into filename 添加主机名
    %e - insert coredumping executable name into filename 添加命令名(程序文件名)
    

1.4 程序崩溃没有core文件

可能是当前执行的命令没有权限改动core_pattern下指定的目录:

$ cat /proc/sys/kernel/core_pattern
core-%e-%p-%t
#或
/corefile/core-%e-%p-%t

可以试试修改core_pattern目录为:

echo "/tmp/core-%e-%p-%t" > /proc/sys/kernel/core_pattern

二、GDB查看core文件堆栈信息

2.1 方法一

  • gdb [exec file] [core file],启动gdb进入core文件,如gdb luajit-2.1.0-beta3 core;或者启动gdb,在gdb中使用file [exec file]命令和core-file [core file]

  • btwhere,可以定位到段错误在源程序中具体文件的具体位置。

    (gdb) bt
    #0  0x000000011f3bf954 in ?? ()
    #1  0x0000000000000000 in ?? ()
    Backtrace stopped: frame did not save the PC
    

2.2 方法二

  • gdb core.xx,调试某个core dump文件,比如gdb core.19122

  • set solib-search-path lib_dir,设置其他依赖库,类似Java需要其他依赖的Jar一样,需要设置其他依赖的动态库,我们环境往往是在set solib-search-path /lib64,下面的所有命令都需要在使用该命令的基础上进行。

  • bt,查看当前线程的栈信息

  • thread apply all bt,输出所有线程的详细栈信息,通常会由此查看是否有自己实现的类或者so库。一般会把所有线程的详细栈信息输出到一个文件里面如thread_info.txt,依次使用下面命令:

    set height 0
    set logging file thread_info.txt
    set logging on
    thread apply all bt
    set logging off
    
  • 19
    点赞
  • 71
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
如果工程很大,头文件很多,而有几个头文件又经常要用的,那么: 1、把这些头文件全部写到一个头文件中,比如:preh.h 2、写一个preh.c,里面的包含库文件,只要一句话#include"preh.h" 3、对于preh.c,在project settings 里面设置creat precompilesd headers ,对于其他.c文件,设置use precompiled header file 。 预编译头文件:就是把一个工程中的那一部分代码,预先编译好放在一个文件里(通常是以.pch为扩展名的),这个文件就成为预编译头文件。这些预先编译好的代码可以是任何的C/C++代码,甚至是inline的函数,但必须是稳定的在工程开发的过程中不会被经常改变。 编译器是以文件为单位编译的,一个文件经过修改后,会重新编译整个文件,当然在这个文件里包含的所有头文件中的东西都要重新处理一遍 预编译头的作用: 根据上文介绍,预编译头文件的作用当然就是提高便宜速度了,有了它你没有必要每次 都编译那些不需要经常改变的代码。编译性能当然就提高了。 预编译头的使用: 要使用预编译头,我们必须指定一个头文件,这个头文件包含我们不会经常改变的 代码和其他的头文件,然后我们用这个头文件来生成一个预编译头文件(.pch文件) 想必大家都知道 StdAfx.h这个文件。很多人都认为这是VC提供的一个“系统级别”的 ,编译器带的一个头文件。其实不是的,这个文件可以是任何名字的。我们来考察一个 典型的由AppWizard生成的MFC Dialog Based 程序的预编译头文件。(因为AppWizard 会为我们指定好如何使用预编译头文件,默认的是StdAfx.h,这是VC起的名字)。我们 会发现这个头文件里包含了以下的头文件: #include // MFC core and standard components #include // MFC extensions #include // MFC Automation classes #include // MFC support for Internet Explorer 4 Common Controls #include 这些正是使用MFC的必须包含的头文件,当然我们不太可能在我们的工程中修改这些头文 件的,所以说他们是稳定的。 那么我们如何指定它来生成预编译头文件。我们知道一个头文件是不能编译的。所以我 们还需要一个cpp文件来生成.pch 文件。这个文件默认的就是StdAfx.cpp。在这个文件 里只有一句代码就是:#include “Stdafx.h”。原因是理所当然的,我们仅仅是要它能 够编译而已?D?D?D也就是说,要的只是它的.cpp的扩展名。 我们可以用/Yc编译开关来指 定StdAfx.cpp来生成一个.pch文件,通过/Fp编译开关来指定生成的pch文件的名字。打 开project ->Setting->C/C++ 对话框。把Category指向Precompiled Header。在左边的 树形视图里选择整个工程  Project Options(右下角的那个白的地方)可以看到 /Fp “debug/PCH.pch”,这就是指 定生成的.pch文件的名字,默认的通常是 .pch(我的示例工程名就是PCH)。 然后,在左边的树形视图里选择StdAfx.cpp.//这时只能选一个cpp文件! 这时原来的Project Option变成了 Source File Option(原来是工程,现在是一个文件 ,当然变了)。在这里我们可以看到 /Yc开关,/Yc的作用就是指定这个文件来创建一个 Pch文件。/Yc后面的文件名是那个包含了稳定代码的头文件,一个工程里只能有一个文 件的可以有YC开关。VC就根据这个选项把 StdAfx.cpp编译成一个Obj文件和一个PCH文件 。 然后我们再选择一个其它的文件来看看,//其他cpp文件 在这里,Precomplier 选择了 Use ⋯⋯⋯一项,头文件是我们指定创建PCH 文件的stda fx.h 文件。事实上,这里是使用工程里的设置,(如图1)/Yu”stdafx.h”。 这样,我们就设置好了预编译头文件。也就是说,我们可以使用预编译头功能了。以 下是注意事项: 1):如果使用了/Yu,就是说使用了预编译,我们在每个.cpp文件的最开头,我强调一遍 是最开头,包含 你指定产生pch文件的.h文件(默认是stdafx.h)不然就会有问题。如 果你没有包含这个文件,就告诉你Unexpected file end. 如果你不是在最开头包含的, 你自己试以下就知道了,绝对有很惊人的效果⋯.. fatal error C1010: unexp

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yelvens

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值