[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)。

相关推荐
信创天地7 分钟前
自动化运维利器赋能信创:Ansible与SaltStack在国产系统的部署与批量管理实战
运维·自动化·ansible
东城绝神11 分钟前
《Linux运维总结:基于ARM64+X86_64架构使用docker-compose一键离线部署MySQL8.0.43 NDB Cluster容器版集群》
linux·运维·mysql·架构·高可用·ndb cluster
creator_Li35 分钟前
即时通讯项目--(1)环境搭建
linux·运维·ubuntu
Ka1Yan1 小时前
Docker:基本概念与快速入门
运维·docker·容器
Mr'liu2 小时前
MongoDB 7.0 副本集高可用部署
linux·mongodb
文静小土豆2 小时前
Rocky Linux 二进制 安装K8S-1.35.0高可用集群
linux·运维·kubernetes
小技工丨2 小时前
华为TaiShan 200 2280 ARM服务器虚拟化部署完整指南
运维·服务器·arm开发
暮云星影3 小时前
二、linux系统 应用开发:整体Pipeline流程
linux·arm开发
weixin_430750934 小时前
OpenMediaVault debian Linux安装配置企业私有网盘(三) 静态ip地址配置
linux·服务器·debian·nas·网络存储系统
403240734 小时前
[Jetson/Ubuntu 22.04] 解决挂载 exFAT 硬盘报错 “unknown filesystem type“ 及只读权限问题的终极指南
linux·运维·ubuntu