首先检查并设置ulimit -c unlimited以启用核心转储,接着配置/etc/sysctl.conf中的kernel.core_pattern指定存储路径与命名格式,然后确保systemd-coredump服务已安装并启用以增强管理能力,最后通过触发段错误程序验证core文件生成及可用性。

如果您在开发或调试 Linux 应用程序时遇到程序异常终止,但缺乏足够的运行时信息,可以通过启用核心转储(Core Dump)来捕获崩溃瞬间的内存状态。以下是配置 Linux 系统以生成 Core Dump 文件的具体步骤。
本文运行环境:Dell XPS 13,Ubuntu 22.04
一、检查并设置系统核心转储限制
Linux 系统默认可能限制了核心转储文件的生成,需通过 ulimit 命令调整进程资源限制,确保允许生成大尺寸的转储文件。
1、打开终端,输入 ulimit -c 查看当前核心文件大小限制。若返回 0,则表示被禁用。
2、执行 ulimit -c unlimited 将限制设为无上限,允许生成完整的内存转储。
3、此设置仅对当前会话生效。如需永久生效,应将其添加到 shell 配置文件中,例如 ~/.bashrc 或 /etc/security/limits.conf。
二、配置系统级核心转储路径与命名规则
通过修改 sysctl 配置可指定核心转储文件的存储位置及文件名格式,便于后续定位和分析。
1、编辑 /etc/sysctl.conf 文件,添加或修改如下行:
kernel.core_pattern=/tmp/core.%e.%p.%t
2、上述格式中,%e 表示可执行文件名,%p 为进程 ID,%t 为时间戳,确保每个转储文件具有唯一性。
还木有评论哦,快来抢沙发吧~