【Linux】进程信号中的 core dump 标记位

这篇具有很好参考价值的文章主要介绍了【Linux】进程信号中的 core dump 标记位。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、什么是core dump

我们知道所有的程序最终运行起来,都会变成进程,进程在运行时可能会异常终止或崩溃,而Linux操作系统会将程序当时的内存状态记录下来,保存在一个文件中,这种行为就叫做Core Dump(中文有的翻译成核心转储)。

保存的这个文件通常是:该进程的同目录下以core.PID的方式命名的文件。

二、core dump的使用

1、开启core dump

在Linux下core dump选项一般是被关闭的,我们可以通过ulimit -a查看当前Linux下系统资源的限制。

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

可以看到,core file size的大小是0,这说明系统不允许我们生成core file文件 ,我们可以使用命令设置生成的core file文件的大小的最大限制。

ulimit -c 10240

可以看到使用此命令以后我们生成的core file文件的大小的最大限制就变为了10240 blocks了。

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

2、生成core file文件

在Linux下有很多信号我们可以使用kill -l查看:

kill -l

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

但是并不是所有的信号引起的退出都会产生core file文件,只有有core标志的信号引起的退出才会产生core file文件,我们可以通过 man 7 signal 查看信号的详细信息

man 7 signal

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

11 号信号SIGSEGV是一个段错误的信号,当你的进程有内存越界等问题时,通常会收到该信号,可以看到该信号是有core标志的。

2号信号SIGINT其实就是我们常用的 Ctrl + C 键产生的信号,可以看到该进程是没有core标志的

下面我们用代码来验证:

#include <iostream>
#include <unistd.h>
using namespace std;

int main()
{
    while (true)
    {
        cout << "我是一个正在运行的进程..." << endl;
        sleep(1);
    }
    return 0;
}

对于这个死循环代码我们使用 Ctrl + C 来进行终止,观察是否有core file文件的产生。

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

可以看到并没有core file文件的生成。

我们再来看下面的代码:

#include <iostream>
#include <unistd.h>
using namespace std;

int main()
{
    int* p = nullptr;
    *p = 10;
    cout << "野指针问题" << endl;
    return 0;
}

很明显这里会收到SIGSEGV信号,而SIGSEGV是有core标志的,因此此进程运行完毕以后应该生成core file文件。

运行结果:

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

可以看到确实生成了core file文件,我们打开该文件:

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器
发现是乱码,这时因为core file里面是数据都是内存中的二进制数据,我们不使用特殊编码是看不懂里面的含义的。

3、验证进程退出码里面的core dump标志位

在以前我们学习进程等待时一定学习过:对于一个存储了进程的退出码的变量,其内部结构是这样的: 次第8位表示退出码,最低7位表示终止信号,终止信号的前一位就是core dump标志位。

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

按照这样的结构,如果我们创建一个子进程,让子进程直接遇到野指针收到SIGSEGV信号直接退出,然后我们在父进程里面检查core dump的标志位是否被置为1

#include <iostream>
#include <cstdlib>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
using namespace std;

int main()
{
    pid_t id = fork();
    if (id == 0)
    {
        // 子进程
        int* p = nullptr;
        *p = 10;
        cout << "野指针问题" << endl;
        exit(0);
    }
    int status = 0;
    wait(&status);

    cout << "子进程的退出信号:" << (status & 0x7F) << endl;
    cout << "子进程的core dump标志位:" << ((status >> 7) & 0x1) << endl;

    return 0;
}

运行结果:

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

当然这个结果是在core dump被开启的条件下,那么我们将core dump关闭运行的结果还会一致吗?

我们继续实验:
【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

运行同样的代码,结果是:

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

可以看到 core dump标志位被改为了0

结论

  1. 同样的程序,在core dump是否开启时会有不同的效果。

  2. 如果core dump开启,遇到有core 标志的信号,会进行核心转储,并且退出码里面的core dump 标志位会被置为1

  3. 如果core dump关闭,遇到有core 标志的信号,也不会进行核心转储,并且退出码里面的core dump 标志位始终置为0

三、 core dump的应用

因为core file 文件内部有进程退出时的内存中的相关信息 ,所以我们可以用这些信息在gdb里面进行调试我们的代码,注意调试的程序要以debug模式发布。

例如下面的代码生成的core file 文件:

#include <iostream>
#include <unistd.h>
using namespace std;

int main()
{
    int* p = nullptr;
    *p = 10;
    cout << "野指针问题" << endl;

    return 0;
}

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器

我们在gdb里面进行调试,然后直接使用下面的命令,gdb就能直接帮我们找到问题的根源了,这种调试手段一般被称为事后调试

core-file core文件

【Linux】进程信号中的 core dump 标记位,linux,linux,运维,服务器文章来源地址https://www.toymoban.com/news/detail-629489.html

到了这里,关于【Linux】进程信号中的 core dump 标记位的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • 『C/C++养成计划』Linux遇到Aborted (core dumped)的处理方法

    C++项目遇到Aborted (core dumped)的处理方法 Core Dump 是一个运行时错误。 Core 的意思是内存, Dump 的意思是扔出来, 堆出来。在开发(或使用)一个程序时,有时程序莫名其妙的 down 了, 却没有任何的提示(有时候会提示 core dumped )。虽然系统没事,但我们下次仍可能遇到相同的问题。这

    2023年04月09日
    浏览(29)
  • 【Linux】调试常见的应用程序奔溃“Segmentation fault (core dumped)”

    Linux程序开发者,日常遇到程序奔溃时,应该如何调试,如何寻找原因和解决呢?本文就介绍了遇到Segmentation fault (core dumped)问题时最常规的定位方法。 当你在命令行执行一个程序时,遇到Segmentation fault (core dumped)后,第一时间查看当前目录下是否产生了core-xxxxx文件。 如果没

    2024年02月10日
    浏览(33)
  • Linux进程信号【信号产生】

    ✨个人主页: 北 海 🎉所属专栏: Linux学习之旅 🎃操作环境: CentOS 7.6 阿里云远程服务器 在 Linux 中,进程具有独立性,进程在运行后可能 “放飞自我”,这是不利于管理的,于是需要一种约定俗成的方式来控制进程的运行,这就是 进程信号 ,本文将会从什么是进程信号

    2024年02月11日
    浏览(36)
  • 【Linux】第八讲:Linux进程信号详解(一)_ 认识信号 | 产生信号

    「前言」文章是关于Linux进程信号方面的知识,本文的内容是Linux进程信号第一讲,讲解会比较细,下面开始! 「归属专栏」Linux系统编程 「主页链接」个人主页 「笔者」枫叶先生(fy)  「枫叶先生有点文青病」「每篇一句」  人生天地间,忽如远行客。 ——《乐府·青青陵上

    2023年04月25日
    浏览(35)
  • Linux进程(一)信号-----信号产生

    在  Linux  中,进程具有独立性,进程在运行后可能 “放飞自我”,这是不利于管理的,于是需要一种约定俗成的方式来控制进程的运行,这就是  进程信号 ,本文将会从什么是进程信号开篇,讲述各种进程信号的产生方式及作用。 信号 是信息传递的承载方式,一种信号往

    2024年02月21日
    浏览(35)
  • Linux进程信号 | 信号处理

    前面的文章中我们讲述了信号的产生与信号的保存这两个知识点,在本文中我们将继续讲述与信号处理有关的信息。 之前我们说过在收到一个信号的时候,这个信号不是立即处理的,而是要得到的一定的时间。从信号的保存中我们可以知道如果一个信号之前被block,当解除

    2024年02月09日
    浏览(33)
  • Linux进程信号【信号处理】

    ✨个人主页: 北 海 🎉所属专栏: Linux学习之旅 🎃操作环境: CentOS 7.6 阿里云远程服务器 从信号产生到信号保存,中间经历了很多,当操作系统准备对信号进行处理时,还需要判断时机是否 “合适”,在绝大多数情况下,只有在 “合适” 的时机才能处理信号,即调用信号

    2024年02月11日
    浏览(30)
  • 【Linux】进程信号之信号的处理

    在前面我们讲过信号产生和保存以后,我们知道进程对于产生的信号不是立即去处理的,而是在\\\"合适\\\"的时候去处理信号, 这是因为信号的产生的异步的,当前进程可能正在做更重要的事情!。 那么信号可以被立即处理吗?答案的可以的,但是要满足这个条件: 在 Linux 中如果

    2024年02月12日
    浏览(39)
  • 【Linux】进程信号之信号的产生

    什么是信号: 信号就是一条消息,它用来通知进程系统中发生了一个某种类型的事件。 信号是多种多样的,并且一个信号对应一个事件,这样才能知道收到一个信号后,到底是一个什么事件,应该如何处理这个信号。 进程在没有收到信号时就已经知道了一个信号应该怎么被处

    2024年02月13日
    浏览(28)
  • 【Linux】进程信号之信号的保存

    实际执行信号的处理动作称为 信号递达(Delivery) 信号从产生到递达之间的状态,称为 信号未决(Pending) 。 进程可以选择阻塞 (Block )某个信号。被阻塞的信号产生时将保持在未决状态,直到进程解除对此信号的阻塞,才执行递达的动作。 注意: 阻塞和忽略是不同的,只要信号被阻

    2024年02月13日
    浏览(32)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包