GDB:遇到segfault但是没有core文件如何定位问题

这篇具有很好参考价值的文章主要介绍了GDB:遇到segfault但是没有core文件如何定位问题。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

生产环境定位问题往往遇到各种限制,比如事后日志发现程序是收到SIGSEGV退出了(segment fault),但是因为:

  1. 没配置limit
  2. 存储空间不够了
  3. 其他未知原因

没有正常生成core文件,那么这会如何定位问题呢?

场景构造

测试程序ctest,明显的空指针错误。

#include <stdio.h>

struct Ctest
{
  int i;
};

int main()
{

  printf("hi\n");
  printf("hi\n");
  struct Ctest *c;
  c->i = 10;
  printf("hi %d\n", c->i);

  printf("hi\n");
  return 0;
}

执行后:

$ ./ctest 
hi
hi
Segmentation fault (core dumped)

但是没有生成core文件。

定位方法1

系统中的任何程序收到SIGSEGV都会记录在内核日志中:

dmesg -T

[Mon Jul 11 15:51:08 2022] ctest[9040]: segfault at 0 ip 0000000000401162 sp 00007ffcc0d3a0a0 error 6 in ctest[401000+1000]

这条日志的含义:

  • 9040:进程号
  • segfault:错误名称
  • ip 0000000000401162:instruction pointer就是代码执行位置的指针
  • sp 00007ffcc0d3a0a0:程序执行栈指针
  • error 6:Architecture-specific flags; see arch/*/mm/fault.c for your platform.

最后的error 6是按二进制来使用的,含义需要找对应平台的fault.c中具体查询。‘’

我们关心的只是程序运行到哪里报错了,所以只需要关注ip 0000000000401162

$ addr2line -e ./ctest 0000000000401162

/tmp/ctest.c:14

可以看到程序在执行14行的时候,收到内核的SIGSEGV。

以上方法是段错误在程序中,那么段错误在共享库中,该如何定位???

扩展

如果程序崩溃在共享库中,例如 process_name[10678]: segfault at 1 ip 00007f6ddc43c650 sp 00000000461b41a8 error 4 in libc-2.4.so[7f6ddc3ca000+127000]

    指令的实际地址是:00007f6ddc43c650 - 7f6ddc3ca000 = 0x72650

    > 可以通过反汇编 objdump -dgS libc-2.4.so > output  然后在output文件中搜索72650,同样也可以定位到具体的函数。

定位方法2

dump二进制编译信息objdump -d ./ctest | more

可以看到401162位置上的movl $0xa,(%rax),直接看汇编代码:

  • 将立即数0xa(十进制的10)赋给寄存器rax记录的地址
  • 但是rax并没有分配任何地址,所以使用非法地址越界报错

(复杂代码的汇编可读性很差,建议使用方法1)

objdump -d ./ctest | more

0000000000401142 <main>:
  401142:       55                      push   %rbp
  401143:       48 89 e5                mov    %rsp,%rbp
  401146:       48 83 ec 10             sub    $0x10,%rsp
  40114a:       bf 10 20 40 00          mov    $0x402010,%edi
  40114f:       e8 dc fe ff ff          callq  401030 <puts@plt>
  401154:       bf 10 20 40 00          mov    $0x402010,%edi
  401159:       e8 d2 fe ff ff          callq  401030 <puts@plt>
  40115e:       48 8b 45 f8             mov    -0x8(%rbp),%rax
  401162:       c7 00 0a 00 00 00       movl   $0xa,(%rax)       # 将立即数0xa(十进制的10)赋给寄存器rax记录的地址
                                                                 # 但是rax并没有分配任何地址,所以使用非法地址越界报错
  401168:       48 8b 45 f8             mov    -0x8(%rbp),%rax   
  40116c:       8b 00                   mov    (%rax),%eax
  40116e:       89 c6                   mov    %eax,%esi
  401170:       bf 13 20 40 00          mov    $0x402013,%edi
  401175:       b8 00 00 00 00          mov    $0x0,%eax
  40117a:       e8 c1 fe ff ff          callq  401040 <printf@plt>
  40117f:       bf 10 20 40 00          mov    $0x402010,%edi
  401184:       e8 a7 fe ff ff          callq  401030 <puts@plt>
  401189:       b8 00 00 00 00          mov    $0x0,%eax
  40118e:       c9                      leaveq 
  40118f:       c3                      retq   

使用GDB来验证下,给地址3赋值,越界访问后收到内核信号SIGSEGV

GDB:遇到segfault但是没有core文件如何定位问题文章来源地址https://www.toymoban.com/news/detail-401219.html

到了这里,关于GDB:遇到segfault但是没有core文件如何定位问题的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 下载了nodejs但是npm -v的时候没有反应如何解决

    小伙伴们,我真的别npm搞哭了,昨天折腾俩小时,整半天没出来,今天早上又整了一个多小时才解决,我必须写篇博客记录一下整个安装nodejs的心路历程!!! 说一下我的问题: 安装nodejs就是正常官网Nodejs官网链接安装,一路next傻瓜安装就行,不过你想中途改安装路径也是

    2024年02月09日
    浏览(35)
  • 【问题记录】Ubuntu 22.04 环境下,程序报:段错误(核心已转储)怎么使用 core 文件和GDB调试器 解决?

    目录 环境 问题情况 解决思路 原因分析 解决方法 番外知识 VMware® Workstation 16 Pro (版本:16.1.2 build-17966106) ubuntu-22.04.2-desktop-amd64 本人在运行百万并发的服务端程序时,程序运行报: 段错误(核心已转储) ,导致程序异常退出,如下 首先要确定核心转储文件的生成路径和

    2024年02月06日
    浏览(31)
  • 笔记本电脑word打字延迟特别大,但是浏览器中打字没有延迟,如何解决这个问题。

    问题描述: 笔记本电脑word打字延迟特别大,但是浏览器中打字没有延迟,如何解决这个问题。( 之前以为是自己的电脑用了6年,用的时间久了,硬件老化导致的,本来想直接换电脑的,但是想着去网上搜一下有没有解决办法,试了几种方法,这种解决了word办公软件打字卡

    2024年02月22日
    浏览(40)
  • .net core 生成项目时.json配置文件没有复制到输出目录

    在程序运行时默认加载.exe文件同文件夹下的配置文件,而不是项目中的.json配置文件,所以需要把.json配置文件设置到自动生成目录,即下图所示:

    2023年04月13日
    浏览(42)
  • 【git】拉取的项目放入idea中,未作任何修改,但是一开始就有文件没有纳入git管理,进行回滚,但是报错filename too long,git拉取代码时就报错filename too long

    我在接手一个新项目时,要做这个项目的需求变更,然后我将这个项目从公司的gitlab上拉下来,但是发现刚拉下来的项目就有很多文件没有纳入git管理和一些文件变更,但是这个是刚拉下来的文件,我没有做任何的操作 尝试切换分支也失败,就是因为识别到本地有内容更改没

    2024年02月05日
    浏览(51)
  • 【C/C++】GDB 快速定位虚函数表并获取详情信息

    首先,使用GDB调试程序,并在程序运行到需要查看虚函数表的地方停下来。 然后,使用命令“p /x (long )object”来查看对象的地址。这个命令会输出对象的地址,例如“0x7fffffffe1c0”。 接着,使用命令“p /x ((long )object + i)”来查看虚函数表中第i个虚函数的地址。这个命令会输

    2023年04月23日
    浏览(23)
  • gpu没有运行进程,但是显存一直占用

    一般停止进程显存会释放,但是如果在不正常情况关闭进程,可能可能会出现显存不释放的情况: 这时需要找到进程: 可能出现 下载包,使用 这时再使用 找到进程: 或者用 最后使用kill -9 118241杀死进程,释放资源.

    2024年02月15日
    浏览(83)
  • js页面当中没有写回车事件,但是有回车效果

    前两天遇到一个问题,研究了我很差事件。问题如下: 页面只有一个文本框,没有写任何回车事件,但是点回车的时候,就会触发回车,回传页面。 于是各种google,终于有了结果: 如果表单里有一个type=”submit”的按钮,回车键生效。 如果  表单里只有一个type=”text”的

    2024年03月09日
    浏览(28)
  • 解决:win10有提示音,但是播视频没有声音

    右下角的声音图标,右键单击,选择\\\"声音”,找到播放,双击负责播放的设备,进入设备属性页,然后取消勾选“启用音频增强”。

    2024年02月12日
    浏览(38)
  • [NSSRound#16 Basic]RCE但是没有完全RCE

    题目代码: 第一个是md5强类型比较,用数组 md5_1[]=1md5_2[]=2 不行,那就用md5碰撞,使用payload: 第二个是md5弱类型比较, 只要两个数的md5加密后的值以0e开头就可以绕过,因为php在进行弱类型比较(即==)时,会先转换字符串的类型,再进行比较,而在比较时因为两个数都是以0e开

    2024年01月23日
    浏览(60)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包