linux上取堆转储快照步骤,Linux下core dump

在linux下开发时,如果程序突然崩溃了,也没有任何日志。这时可以查看core文件。从core文件中分析原因,通过gdb看出程序挂在哪里,分析前后的变量,找出问题的原因。

Core Dump

当程序运行的过程中异常终止或崩溃,操作系统会将程序当时的内存状态记录下来,保存在一个文件中,这种行为就叫做Core Dump(中文有的翻译成“核心转储”)。我们可以认为 core dump 是“内存快照”,但实际上,除了内存信息之外,还有些关键的程序运行状态也会同时 dump 下来,例如寄存器信息(包括程序指针、栈指针等)、内存管理信息、其他处理器和操作系统状态和信息。core dump 对于编程人员诊断和调试程序是非常有帮助的,因为对于有些程序错误是很难重现的,例如指针异常,而 core dump 文件可以再现程序出错时的情景。

相关设置

如果没有进行core dump 的相关设置,默认是不开启的。可以通过ulimit -c查看是否开启。如果输出为0,则没有开启,需要执行ulimit -c unlimited开启core dump功能。

ulimit

ulimit命令用来限制系统用户对shell资源的访问。限制 shell 启动进程所占用的资源,支持以下各种类型的限制:所创建的内核文件的大小、进程数据块的大小、Shell 进程创建文件的大小、内存锁住的大小、常驻内存集的大小、打开文件描述符的数量、分配堆栈的最大大小、CPU 时间、单个用户的最大线程数、Shell 进程所能使用的最大虚拟内存。同时,它支持硬资源和软资源的限制。

ulimit相关选项如下:

-a:显示目前资源限制的设定;

-c :设定core文件的最大值,单位为区块;

-d :程序数据节区的最大值,单位为KB;

-f :shell所能建立的最大文件,单位为区块;

-H:设定资源的硬性限制,也就是管理员所设下的限制;

-m :指定可使用内存的上限,单位为KB;

-n :指定同一时间最多可开启的文件数;

-p :指定管道缓冲区的大小,单位512字节;

-s :指定堆叠的上限,单位为KB;

-S:设定资源的弹性限制;

-t :指定CPU使用时间的上限,单位为秒;

-u :用户最多可开启的程序数目;

-v :指定可使用的虚拟内存上限,单位为KB。

复制代码

core文件的名称和生成路径:

没有进行设置的话,默认生成的core文件不带其它任何扩展名称,全部命名为core。新的core文件生成将覆盖原来的core文件 。 可对core文件的名称和生成路径进行相关配置,如下:

/proc/sys /kernel/core_uses_pid可以控制core文件的文件名中是否添加pid作为扩展。文件内容为1,表示添加pid作为扩展名,生成的 core文件格式为core.xxxx;为0则表示生成的core文件同一命名为core。

proc/sys/kernel/core_pattern可以控制core文件保存位置和文件名格式。

以下是参数列表:

%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时间

%h - insert hostname where the coredump happened into filename 添加主机名

%e - insert coredumping executable name into filename 添加命令名

复制代码

示例:

会产生错误的代码如下:

#include

#include

#include

#include

#define CORE_SIZE 500 * 1024 * 1024

int main(){

struct rlimit rlmt;

if (getrlimit(RLIMIT_CORE, &rlmt) == -1) {

return -1;

}

printf("Before set rlimit core dump current is:%d, max is:%d\n", (int)rlmt.rlim_cur, (int)rlmt.rlim_max);

rlmt.rlim_cur = (rlim_t)CORE_SIZE;

rlmt.rlim_max = (rlim_t)CORE_SIZE;

if (setrlimit(RLIMIT_CORE, &rlmt) == -1) {

return -1;

}

if (getrlimit(RLIMIT_CORE, &rlmt) == -1) {

return -1;

}

printf("After set rlimit core dump current is:%d, max is:%d\n", (int)rlmt.rlim_cur, (int)rlmt.rlim_max);

// 对空指针指向的内存区域写,会发生段错误 -->产生core文件

int *null_ptr = NULL;

*null_ptr = 10;

return 0;

}

复制代码

使用 gcc 编译源文件,加上 -g 以增加调试信息;执行会产生错误,生成core文件。d3bf1eb672368e762e5f31ebb4be1c88.png

执行gdb core后输出信息如下图:c086738780eb0fdb96475a7cb5357959.png

gdb core: 用gdb同时调试一个运行程序和core文件,core是程序非法执行后core dump后产生的文件。可以看到程序的问题是core_dump.c文件中第31行对一个空指针赋值的错误提示。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值