Linux系统调试中出现核心转储(core dump)的问题

简介: Linux系统调试中出现核心转储(core dump)的问题

   大家好,我是ST。今天主要分享一下,Linux应用程序发生Segmentation fault段错误时,如何利用core dump文件定位错误。

核心转储

在 Linux 系统中,常将“主内存”称为核心(core),核心映像(core image) 就是 “进程”(process)执行当时的内存内容。

当进程发生错误或收到“信号”(signal) 而终止执行时,系统会将核心映像写入一个文件,以作为调试之用,这就是所谓的核心转储(core dump)。

当在一个程序崩溃时,系统会在指定目录下生成一个core文件,我们就可以通过 core文件来对造成程序崩贵的原因进行调试定位。

开启核心转储

Linux 默认没有打开core文件生成功能,也就是发生段错误时不会core dumped。可以通过以下命令打开core文件的生成:

# 不限制产生 core 的大小
ulimit -c unlimited

unlimited 意思是系统不限制core文件的大小,只要有足够的磁盘空间,会转存程序所占用的全部内存,如果需要限制系统产生 core 的大小,可以使用以下命令:

# core 最大限制大小为 409600 字节
ulimit -c 409600

把核心转储功能关闭,只需要将限制大小设为0 即可:

ulimit -c 0

注意,如果只是输入命令“ulimit -c unlimited”,这只会在当前终端有效,退出终端或者打开一个新的终端时是无效的。因此可以在将上述配置加入到 /etc/profile 中:

# 编辑 profile 文件
vi /etc/profile
# 将下行加到入profile 文件中
ulimit -c unlimited

使用GDB调试core文件

编写一个简单的C程序,人为制造一个Segmentation fault错误:

#include <stdio.h>
#include <stdlib.h>
int main(int argc, char **argv)
{
  int *p = NULL;
  // 给一个NULL指令赋值,会产生 Segmentation fault 错误
  *p = 100;
  return 0;
}

上述代码中定义了一个空指针变量P,然后给空指针P赋值,运行程序就会产生一个段错误

开启了核心转储后,就会产生一个 core 文件。

# 编译 hello.c 生成 hello 程序
gcc -o hello hello.c -g
# 运行该程序
./hello

运行后,我们可以看到 Segmentation fault (core dumped) 提示信息,表示已经在当前目录下产生了一个core 文件:

下面就可以通过 core 来进行调试,使用 GDB 调式 core 的命令格式如下:

gdb <程序> <core文件>

输入以下命令:

gdb hello core

通过 GDB 可以看到程序的第9行出错。第9行变量p是一个空指针,所以产生了错误。

可能遇到的问题

有些同学通过ulimit -c unlimited打开了核心转储,并且段错误时也有Segmentation fault (core dumped) 提示信息,但是当前目录下没有看到core文件的生成

这是因为core文件的默认生成路径不对,只要发生段错误时,括号里出现了core dumped就代表core文件已生成。

可以通过以下命令查看core文件的存放路径:

cat /proc/sys/kernel/core_pattern

上述情况就代表core文件被存放到了指定路径。

修改core文件生成路径为当前目录下,输入命令:

echo core /proc/sys/kernel/core_pattern

注意使用root用户权限

修改后,core文件就会在当前目录下生成。

相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
目录
相关文章
|
1月前
|
存储 监控 Shell
【Shell 命令集合 备份压缩 】Linux 备份文件系统 dump命令 使用指南
【Shell 命令集合 备份压缩 】Linux 备份文件系统 dump命令 使用指南
37 0
|
1月前
|
NoSQL 安全 Linux
Linux 中 core dump 文件的作用和使用方法
Linux 中 core dump 文件的作用和使用方法
91 1
|
1月前
|
存储 Shell Linux
【Shell 命令集合 备份压缩 】Linux 恢复由dump命令创建的备份文件 restore命令 使用指南
【Shell 命令集合 备份压缩 】Linux 恢复由dump命令创建的备份文件 restore命令 使用指南
36 0
|
6月前
|
开发框架 .NET Linux
ASP.NET Core部署到linux(CentOS)
ASP.NET Core部署到linux(CentOS)
161 0
ASP.NET Core部署到linux(CentOS)
|
5月前
|
存储 NoSQL Linux
【Linux】进程信号中的 core dump 标记位
【Linux】进程信号中的 core dump 标记位
|
5月前
|
NoSQL Linux
Linux下怎样使用core文件查看异常崩溃的程序问题
之前在写程序的时候,遇到了意外崩溃的问题,但是当时并没有生成core文件,想用gdb 对程序进行单步跟踪时,并不能复现。所以想要用core文件看看到底是哪里的问题,这里把问题记录下来当再次遇到时可以解决。
73 0
|
Linux 数据安全/隐私保护 Ubuntu
Linux必杀(十七):完整备份工具(dump)
题记: 例一:用dump备份完整的文件系统 1。找出系统中最小的那个文件系统 wd@wd:~$ sudo su [sudo] wd 的密码: root@wd:/home/wd# cd ~ root@wd:~# ...
1912 0
|
7天前
|
机器学习/深度学习 缓存 监控
linux查看CPU、内存、网络、磁盘IO命令
`Linux`系统中,使用`top`命令查看CPU状态,要查看CPU详细信息,可利用`cat /proc/cpuinfo`相关命令。`free`命令用于查看内存使用情况。网络相关命令包括`ifconfig`(查看网卡状态)、`ifdown/ifup`(禁用/启用网卡)、`netstat`(列出网络连接,如`-tuln`组合)以及`nslookup`、`ping`、`telnet`、`traceroute`等。磁盘IO方面,`iostat`(如`-k -p ALL`)显示磁盘IO统计,`iotop`(如`-o -d 1`)则用于查看磁盘IO瓶颈。
|
3天前
|
监控 Linux Windows
50个必知的Linux命令技巧,你都掌握了吗?(下)
50个必知的Linux命令技巧,你都掌握了吗?(下)