gdb调试产生code文件以及遇到的“file format not recognized”问题解决

简介: gdb调试产生code文件以及遇到的“file format not recognized”问题解决

一、调试 core 文件的配置

1.1 开启core文件 —— ulimit

有时候,服务器程序运行一段时间后会突然崩溃,这并不是我们希望看到的,需要

解决这个问题。只要程序在崩溃的时候有 core 文件产生,就可以使用这个 core 文件

来定位崩溃的原因。当然,Linux 系统默认是不开启程序崩溃产生 core 文件这一机制

的,我们可以使用 ulimit -c 命令来查看系统是否开启了这一机制。发现 core file size 那一行默认是 0,表示关闭生成 core 文件。

9e1160fbb8e7393c9810f345dc9e169d_3378ba48dd89447382049bf52dc98698.png

如何开启

1)使用 ulimit -c unlimited(unlimited 是 -c 选项值)直接修改成不限制大小。

2)然后执行source /etc/profile即可立即生效。

3)再次查看 ulimit -c,结果为unlimited表示修改成功。

b9ea112f75647664935e01f5adea2356_fd677ddf726546fb9bd7c8f947f8001e.png


1.2 设置core文件生成地址

系统默认 corefile 是生成在程序的执行目录下或者程序启动调用了 chdir 之后的目录。我们可以通过设置生成 corefile 的格式来控制它,让其生成在固定的目录下

1)打开/etc/sysctl.conf


sudo vim /etc/sysctl.conf

2)在文件最后,写入 corefile 文件生成的目录

kernel.core_pattern=/home/zxm/codedump/core_%e_%p_%t

ab91fa8df5cbdce46c7c8322ba5a763c_be3b6a6a19a44b7ba3647298d9293481.png

%e 所dump的文件名

%p 所dump的进程PID

%t 转储时刻(由1970年1月1日起计的秒数)


3)执行生效

sudo sysctl -p /etc/sysctl.conf

4)使用 cat 去查看路径是否生效

cat /proc/sys/kernel/core_pattern

76f1cc320f09cd7cbe8f9bd68ca503d1_e4cf4faf7dd841aba055b56250fe8161.png


1.3 测试

#include <stdio.h>
int main(void)
{
    printf("hello world! dump core for set value to NULL pointer/n");
    *(char *)0 = 0;
    return 0;
}

1)编译运行

gcc -g -o core_dump core_dump.c
./core_dump

结果是Segmentation fault


2)到/home/zxm/codedump,输入ll查看

11465f4298fddf00adedf7226af18afa_10b14539f88d4779a89c55ecba8cfd65.png

3)有core文件,使用 gdb 进行调试。从结果看,提示出错位置在第6行


gdb ./core_dump /home/zxm/codedump/core_core_dump_2369_1689412339

ed5cba945f8c25d7f19631fcba5816ac_b26cb3d5878e48a0bc4cea8608cac9a2.png

1.4 无法产生code文件和file format not recognized报错

1)没有产生code文件

一开始调试的时候,并没设置路径。因为默认是程序运行的目录下,但是执行后没有产生。

9839aa37387ff148db1e985aee011b84_466c5110649c4d709becd43a767b8f42.png

2)file format not recognized报错

后面,设置的路径是/home/zxm/share/codedump,share是我的共享文件夹。这个时候报错

"/home/zxm/share/coredump/core_core_dump_2186" is not a core dump: file format not recognized

1ecbb124984208bb95911222ea7b63ee_4d2a7e1c9b0948c18c2334c8659f0ed8.png

检查一下coredump,发现生成的code文件是0。那就是先前ulimit -c unlimited没设置成功。

94df2920910f9806f435d45f1adde5bb_c2f9808277224a3694f8c4c3ce009572.png

3)解决办法

最后解决方法:不要把coredump创建在自己共享文件夹下。我这边修改到/home/zxm/codedump,再运行一次,就ok了;

ed5cba945f8c25d7f19631fcba5816ac_b26cb3d5878e48a0bc4cea8608cac9a2.png

11465f4298fddf00adedf7226af18afa_10b14539f88d4779a89c55ecba8cfd65.png

相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
目录
相关文章
|
3月前
|
NoSQL Linux C语言
Linux GDB 调试
Linux GDB 调试
62 10
|
3月前
|
NoSQL Linux Windows
geopandas直接支持gdb文件写出与追加
geopandas直接支持gdb文件写出与追加
|
3月前
|
NoSQL 数据挖掘 定位技术
如何让geopandas支持写出gdb文件
如何让geopandas支持写出gdb文件
|
3月前
|
NoSQL Linux C语言
嵌入式GDB调试Linux C程序或交叉编译(开发板)
【8月更文挑战第24天】本文档介绍了如何在嵌入式环境下使用GDB调试Linux C程序及进行交叉编译。调试步骤包括:编译程序时加入`-g`选项以生成调试信息;启动GDB并加载程序;设置断点;运行程序至断点;单步执行代码;查看变量值;继续执行或退出GDB。对于交叉编译,需安装对应架构的交叉编译工具链,配置编译环境,使用工具链编译程序,并将程序传输到开发板进行调试。过程中可能遇到工具链不匹配等问题,需针对性解决。
|
3月前
|
NoSQL
技术分享:如何使用GDB调试不带调试信息的可执行程序
【8月更文挑战第27天】在软件开发和调试过程中,我们有时会遇到需要调试没有调试信息的可执行程序的情况。这可能是由于程序在编译时没有加入调试信息,或者调试信息被剥离了。然而,即使面对这样的挑战,GDB(GNU Debugger)仍然提供了一些方法和技术来帮助我们进行调试。以下将详细介绍如何使用GDB调试不带调试信息的可执行程序。
102 0
|
5月前
|
NoSQL Linux C语言
Linux gdb调试的时候没有对应的c调试信息库怎么办?
Linux gdb调试的时候没有对应的c调试信息库怎么办?
42 1
|
5月前
|
NoSQL Linux C语言
Linux gdb调试的时候没有对应的c调试信息库怎么办?
Linux gdb调试的时候没有对应的c调试信息库怎么办?
31 0
|
5月前
|
NoSQL Linux C++
Linux C/C++ gdb调试正在运行的程序
Linux C/C++ gdb调试正在运行的程序
|
5月前
|
NoSQL Linux C++
Linux C/C++ gdb调试core文件
Linux C/C++ gdb调试core文件
|
5月前
|
NoSQL Linux C++
Linux C/C++ gdb调试
Linux C/C++ gdb调试