[coredump] 生成管理

在 Linux 系统中,core dump 文件的生成路径和文件名可以通过几个方面来控制:

  1. 系统默认路径
    • 默认情况下,core dump 文件通常生成在程序的工作目录,即程序运行时的当前目录。
    • 文件名通常为 core,或者在某些系统上可能包含进程 ID,如 core.PID,其中 PID 是产生 core dump 的进程的进程 ID。
  2. /proc/sys/kernel/core_pattern
    • Linux 系统提供了一个内核参数 core_pattern,它决定了 core dump 文件的位置和命名方式。

    • 可以通过编辑 /proc/sys/kernel/core_pattern 文件来设置 core dump 的路径和命名规则。例如,可以将 core dump 存储在 /var/coredumps/ 目录下,并按照进程名和 PID 命名,如下所示:

      复制代码
      echo "/var/coredumps/core-%e-%p-%t" > /proc/sys/kernel/core_pattern

      这将导致 core dump 文件以 core-<命令名>-<PID>-<时间戳> 的格式存储在 /var/coredumps/ 目录下。

  3. ulimit 命令
    • 使用 ulimit 命令可以控制 core dump 文件的大小限制。例如,设置无限制的 core dump 大小可以使用:

      复制代码
      ulimit -c unlimited
    • 如果将 core dump 大小限制为 0,则系统不会生成 core dump 文件。

  4. systemd 配置
    • 如果你的系统使用 systemd 作为初始化系统,你还可以在 systemd 的配置文件中设置 core dump 的行为。
  5. 环境变量
    • 环境变量 CORE_PATTERN 也可以用来控制 core dump 文件的路径和命名。
      请注意,要生成 core dump 文件,你的系统必须允许生成 core dump,并且用户必须有权限在指定的目录下写入文件。此外,某些安全设置或系统限制可能会阻止 core dump 文件的生成。

附加ulimit的用法

ulimit 是一个在类 UNIX 系统中用于设置或报告用户资源限制的命令。其中,-c 选项用于控制核心转储(core dump)文件的大小限制。

ulimit -c 的用法:

  1. 查看当前 core dump 文件大小限制:
bash 复制代码
ulimit -c
  1. 设置 core dump 文件大小限制为无限制(unlimited):
bash 复制代码
ulimit -c unlimited
  1. 设置 core dump 文件大小限制为一个具体的值(例如,1024KB):
bash 复制代码
ulimit -c 1024

代码演示:

假设我们有一个简单的 C 程序 div_zero.c,它包含一个除以零的操作,这将导致程序异常终止并生成 core dump 文件。

c 复制代码
#include <stdio.h>
int main() {
    int a = 10;
    int b = 0;
    int result = a / b; // 这里将产生除以零的错误
    printf("Result: %d\n", result);
    return 0;
}

编译并运行这个程序,然后检查 core dump 文件的大小限制和生成情况。

  1. 编译程序:
bash 复制代码
gcc -g -o div_zero div_zero.c
  1. 查看当前 core dump 文件大小限制:
bash 复制代码
ulimit -c
  1. 设置 core dump 文件大小限制为无限制:
bash 复制代码
ulimit -c unlimited
  1. 运行程序(这将导致除以零的错误并生成 core dump 文件):
bash 复制代码
./div_zero
  1. 检查 core dump 文件是否生成:
bash 复制代码
ls core.*

请注意,ulimit 设置的更改通常只影响当前会话。如果你希望永久更改 core dump 文件大小限制,你可能需要编辑 shell 的配置文件(如 .bashrc.bash_profile)或系统范围的配置文件(如 /etc/security/limits.conf)。

相关推荐
BigBigHang2 分钟前
【docker】cloudbeaver的docker-compose及一些踩坑
运维·docker·容器
pengdott2 分钟前
Linux进程数据结构与组织方式深度解析
linux·运维·服务器
Java 码农3 分钟前
gitlab gitrunner springboot 多环境多分支部署 (非容器方式,使用原生linux 环境)
linux·spring boot·gitlab
小快说网安16 分钟前
等保测评通过后,如何持续满足安全运维要求?
运维·安全·网络安全·等保测评
闲过信陵饮~18 分钟前
无头服务器 + Vulkan + Docker 问题
运维·docker·容器
科技块儿18 分钟前
【需求:GDPR合规下做地域定向】解决方案:仅用IP离线库输出国家码,不存原始IP?
服务器·网络·tcp/ip
LongQ30ZZ18 分钟前
Linux的常见指令
linux·服务器
走向IT20 分钟前
vdbench在Centos系统上联机测试环境搭建
linux·运维·centos
阳宗德24 分钟前
基于CentOS Linux release 7.1实现了Oracle Database 11g R2 企业版容器化运行
linux·数据库·docker·oracle·centos
·云扬·28 分钟前
MySQL运维效率提升:实用SQL语句合集
运维·sql·mysql