首先检查并设置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 为时间戳,确保每个转储文件具有唯一性。
3、保存后执行 sysctl -p 命令加载新配置。
systemd-coredump 是现代 Linux 发行版中用于捕获、存储和管理核心转储的服务组件,提供更精细的控制能力。
1、确认 systemd-coredump 是否已安装,可通过命令 systemctl status systemd-coredump 检查服务状态。
2、若未启用,安装对应软件包(如 Ubuntu 中为 systemd-coredump),然后运行 sudo systemctl enable systemd-coredump 启用服务。
3、配置文件位于 /etc/systemd/coredump.conf,可根据需要调整存储路径、大小限制等参数。
在完成配置后,必须通过实际测试确认系统能够正确生成核心转储文件。
1、编写一个简单的会触发段错误的 C 程序,例如访问空指针。
2、编译并运行该程序,观察是否在预设路径(如 /tmp)下生成了对应的 core 文件。
3、使用 file core.* 命令确认文件类型,并用 gdb 加载进行初步分析,例如执行 gdb ./executable core。
以上就是LINUX如何设置Core Dump_在LINUX程序崩溃时生成核心转储文件进行调试的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号