配置(9):在ubuntu上生成core文件

1. 启用核心转储功能(当前终端生效)

ulimit -c unlimited

该命令用于解除系统对核心转储文件大小的限制,确保程序崩溃时能生成core文件。

检查 core 文件的生成路径和权限

cat /proc/sys/kernel/core_pattern

  • 如果输出是 core,则表示默认生成在当前目录。
  • 如果输出是类似 |/usr/share/apport/apport %p %s %c %d %P 的内容,说明系统使用了 apport 等工具来处理崩溃,这可能会阻止 core 文件的生成。
  • 如果输出是 /var/crash/core.%p,则 core 文件会生成在 /var/crash/ 目录下,并且文件名包含进程 PID。

如何修改 core_pattern (需要 root 权限)

临时修改(重启后失效)

sudo sysctl -w kernel.core_pattern=core

永久修改(需要编辑配置文件)

sudo vim /etc/sysctl.conf

添加或修改一行:

kernel.core_pattern = core sudo sysctl -p

2. 重新触发段错误以生成core文件

./kvstore

程序崩溃后 ,在当前目录下查找名为 corecore.<pid> 的文件。

ls -l core*

3. 重新用 GDB 调试core文件 (编译时加-g,core可以生成更多信息)

gdb ./kvstore core.20860

<RET>是指回车键

|-----------|--------------------------|
| bt full | 获取崩溃时的函数调用链及局部变量,定位具体错误点 |

相关推荐
Bdygsl6 分钟前
MySQL(4)—— 表设计
数据库·mysql
2301_8194143010 分钟前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python
未来龙皇小蓝28 分钟前
【MySQL-索引调优】09:Order By相关概念
数据库·mysql·性能优化
未来龙皇小蓝31 分钟前
【MySQL-索引调优】10:常见的分页优化处理
数据库·mysql·性能优化
God__is__a__girl35 分钟前
Oracle驱动版本引发ORA-01461批量插入异常排查与解决
数据库·oracle
少年攻城狮1 小时前
Oracle系列---【两个环境,表结构一致,数据量一致,索引也一致,为什么同样的sql执行时间却不一致?】
数据库·sql·oracle
l1t1 小时前
解决用docker安装umbra数据库遇到的FATAL:Operation not permitted错误
数据库·docker·容器
柯儿的天空1 小时前
【OpenClaw 全面解析:从零到精通】第 006 篇:OpenClaw 在 Windows/WSL2 上的安装与部署实战
人工智能·windows·语言模型·chatgpt·ai作画
2401_894241921 小时前
机器学习与人工智能
jvm·数据库·python
GentleDevin1 小时前
Redis服务常用命令
数据库·oracle