Linux程序崩溃调试

一、简单点的

编译时主动带-g,生成的程序带调试信息,而且开启生成dump文件,这时候可以使用core dump来调试程序,定位问题。可以参考:linux 程序crash 调试、原因分析及问题定位-CSDN博客

二、稍微复杂点

假设生成的可执行文件带了调试信息,那么可以考虑用gdb来调试程序,调试的教程如下:gdb调试

三、再复杂点:如果core dump文件的堆栈信息被破坏了,又该如何定位问题呢?

参考下面博文,借助栈帧信息和寄存器信息来使用gdb-x命令排查问题

四、定位排查问题实战:没有core文件时定位segfault at 0 ip (null) 的问题

上连接:没有core文件时定位段错误问题

五、崩溃时要是没有core dump文件生成,那又该如何排查问题?

借助内核的segfault日志来定位问题:内核segfault定位程序崩溃

写在最后:

coredump文件是如何生成的?

相关推荐
开压路机4 小时前
进程控制
linux·服务器
香蕉鼠片4 小时前
跨平台开发到底是什么
linux·windows·macos
bukeyiwanshui6 小时前
20260417 DNS实验
linux
代码中介商6 小时前
Linux 帮助手册与用户管理完全指南
linux·运维·服务器
weixin_449173658 小时前
Linux -- 项目中查找日志的常用Linux命令
linux·运维·服务器
想唱rap9 小时前
C++智能指针
linux·jvm·数据结构·c++·mysql·ubuntu·bash
Strugglingler10 小时前
基于whiptail开发shell导航工具
linux·shell·ui设计·whiptail
艾醒(AiXing-w)10 小时前
Linux系统管理(二十)——Linux root磁盘不足?一站式应急清理方案(亲测可用)
linux·运维·服务器
小义_10 小时前
【Kubernetes】(五) pod2
linux·云原生·容器·kubernetes
哇哦98211 小时前
渗透安全(渗透防御)②
linux·安全·渗透防御