【Linux】详解core dump文件的作用以及用法&&ubuntu20.04下无法形成core dump文件的解决办法

简介: 【Linux】详解core dump文件的作用以及用法&&ubuntu20.04下无法形成core dump文件的解决办法

说明

       从第三大点开始讲解ubuntu20.04下无法形成core dump文件的解决办法。

一、core与term的区别

       在之前讲过的信号中,终止进程的信号的动作分为两种,一种是core,一种是term。term(全称termination)是直接终止进程;而core的动作同样是终止进程,但是core在终止进程的同时会给我们形成core dump文件。

二、core dump文件的作用

        当进程收到动作为core的信号发生异常退出时,将进程在内存中的核心数据(主要是与调试有关的核心数据)转储到磁盘中形成core dump文件,core dump文件可以帮助程序员定位到程序为什么退出以及是在哪一行退出的。它包含了崩溃时的内存状态信息,如变量值、函数调用栈等。core文件可以用来检查内存泄漏,因为它包含了程序在崩溃时的内存状态信息,通过分析可以找出哪些内存没有被释放。有时候程序崩溃是难以复现的,生成core dump文件可以帮助程序员在不同的环境中重现问题,以便更好地调试。利用core dump文件调试也叫做事后调试

三、开启core文件功能

在Linux系统上,core dump文件的生成默认是关闭的。

默认core文件的大小为零,也就是关闭的。

下面是core文件生成的打开方法。

ulimit -c 10240(设置core dump文件的文件大小,单位为kb)

        设置完成以后,我们就可以看到core文件的大小变为我们设置的大小了。下面我写一段测试代码:

#include <iostream>
using namespace std;
 
int main()
{
    int a = 10;
    a /= 0;
    return 0;
}

        此时我已经设置了core文件的大小,core dumped功能已经打开,可在当前目录下却没有形成core文件:

这是在ubuntu20.04系统下会产生的结果,下面我会讲解解决的方法。

三、ubuntu20.04下无法形成core文件的解决办法

3.1、解决方法

需要在root用户或者是用sudo提权执行这条指令:

sudo bash -c "echo core > /proc/sys/kernel/core_pattern"

       在ubuntu20.04这个系统下,/proc/sys/kernel/core_pattern路径下的这个core_pattern文件的内容默认是空的,执行sudo  "echo core > /proc/sys/kernel/core_pattern"这条指令是用来设置内核的 core dump 模式的。当你设置core_pattern为 "core",系统会在程序崩溃并产生 core dump 时,将 core dump 文件命名为core而不是默认的带有进程 ID 和其他信息的文件名。 也就是说,形成的core dump文件的名称是可以自定义的,但我还是建议将core dump文件的名称就设置为core。

先设置core dump文件的大小:

执行该条指令,运行我的可执行程序,发生除0错误,这次就会形成core dump文件了。

core可以帮助调试,直接帮我们指定错误在第几行:

2、向core_pattern文件中写入内容时的细节

       这也是我在写入core到core_pattern文件中所遇到的问题。刚开始我是用vim向core_pattern文件中写入core的,但在保存退出的时候遇到了下面这个问题:

       原因是因为操作系统proc目录中的文件并不是实际的文件。/proc目录在Linux系统中是一个伪文件系统,它只存在于内存中,并不占用实际的磁盘空间。这个目录下的文件并不是真正的文件和目录,而是内核运行时的一些信息、状态和参数的接口。这些文件通常用于查看和修改内核参数、系统状态、硬件信息等。

       由于/proc目录下的文件并不对应实际的磁盘上的数据,因此它们不能被常规的文本编辑器(如vim)进行编辑。实际上,当你尝试使用vim或其他文本编辑器打开并修改/proc下的文件时,你实际上是在尝试修改内核的状态或参数,而这是不被允许的。所以修改/proc下的文件时更常见的是使用shell命令。

四、总结

       看了有的文章说禁用apport功能也能正常在当前目录下形成core dump文件,但是在ubuntu20.04这个系统下我已经尝试过了,并不能解决这个问题,大家也可以尝试一下这个方法看看。

相关文章
|
5月前
|
Ubuntu 编译器 计算机视觉
Ubuntu 20.04环境下无法找到#include<opencv/cv.h>文件 - 解决方案。
希望这些信息能帮助你解决遇到的问题。
345 10
|
8月前
|
存储 数据管理 Linux
区分Linux中.tar文件与.tar.gz文件的不同。
总之,".tar"文件提供了一种方便的文件整理方式,其归档但不压缩的特点适用于快速打包和解压,而".tar.gz"文件通过额外的压缩步骤,尽管处理时间更长,但可以减小文件尺寸,更适合于需要节约存储空间或进行文件传输的场景。用户在选择时应根据具体需求,考虑两种格式各自的优劣。
1389 13
|
9月前
|
Ubuntu Linux UED
Ubuntu和Debian系统与Hat Linux系列的使用比较
所以,如果你想搞一个家用服务器,或者是个人使用,喜欢新鲜事物,那Ubuntu可能是你的最好选择。如果你需要一个在商业环境中经受住考验的系统,那Fedora或CentOS可能更符合你的口味。不过记住,CentOS现在是CentOS Stream,中途换马了,所以如果你是稳定性的极端追求者,可能得考虑一下这一变化。而Debian,则适合那些对稳定性需求极高,不太追求软件版本新旧的用户。
323 26
|
8月前
|
Ubuntu 安全
修复Ubuntu系统文件损坏问题:手动fsck指令
总结一下,使用 `fsck`修复文件系统是一个复杂的过程,涉及到诊断问题、安全卸载文件系统、执行检查与修复、并且通常在维护模式下完成。这个过程对于维护系统的健康和稳定至关重要。虽然命令和步骤可以按照标准手册执行,但每个系统的具体情况可能都有所不同,因此修复操作需要对系统和维护命令有所了解。在执行这一系列操作时请确保谨慎,并对系统有一定的认识,以避免不必要的数据丢失。
1279 8
|
7月前
|
缓存 监控 Ubuntu
Ubuntu操作系统下清除系统缓存与无用文件的方法
通过上述步骤断行综合性地对Ubuntu进行优化与整洁可显著改善其性能表现及响应速度。然而,请注意在执行某些操作前确保充分了解其潜在影响;例如,在移除旧内核之前确认新内核稳定运行无问题;而对于关键配置更改则需确保备份好相关设置以便恢复原状态。
1851 0
|
9月前
|
安全 Linux
Linux赋予文件000权限的恢复技巧
以上这些步骤就像是打开一扇锁住的门,步骤看似简单,但是背后却有着严格的逻辑和规则。切记,在任何时候,变更文件权限都要考虑安全性,不要无谓地放宽权限,那样可能
279 16
|
9月前
|
Ubuntu 安全 Linux
详述Ubuntu中的/etc/rc.local与/etc/init.d/rc.local文件的不同应用场景
总结一下,`/etc/rc.local`和 `/etc/init.d/rc.local`可以说是系统自定义服务的二人转。在Systemd登基以前,`/etc/rc.local`是大明星,负责在系统启动的最后一刻执行任务。而 `/etc/init.d/rc.local`则扮演着保证 `rc.local`文件内容可以被执行的幕后角色。随着Ubuntu版图的更迭和Systemd的崛起,两者都有所转变,但它们依旧是实现系统自启动自定义命令和程序的得力工具,虽然现在要通过一些额外的设置来唤醒它们的能力。此外,由于Systemd的灵活性和强大,推荐使用更加现代化的Systemd单元(unit)文件来替代这
385 10
|
8月前
|
监控 Linux 应用服务中间件
linux查看日志文件tail -f用法
在 Linux 中,查看和监控日志文件是系统管理员和开发者常用的操作之一。tail 命令就是用来查看文件内容的,它默认显示文件的最后部分。tail -f 是 tail 命令的一个非常有用的选项,用于实时查看和跟踪日志文件的更新,尤其是在监控运行中的服务时非常有用。
1029 0
|
9月前
|
存储 Linux 数据处理
深入剖析Linux中一切即文件的哲学和重定向的机制
在计算机的奇妙世界中,Linux的这套哲学和机制减少了不同类型资源的处理方式,简化了抽象的概念,并蕴藏着强大的灵活性。就像变戏法一样,轻轻松松地在文件、程序与设备之间转换数据流,标准输入、输出、错误流就在指尖舞动,程序的交互和数据处理因此变得既高效又富有乐趣。
163 4
|
NoSQL Linux 关系型数据库
linux coredump配置与调试
Linux Core Dump 配置与调试1.core文件的生成开关和大小限制---------------------------------1)使用ulimit -c命令可查看core文件的生成开关。
1697 0