配置(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 | 获取崩溃时的函数调用链及局部变量,定位具体错误点 |

相关推荐
野生技术架构师1 小时前
数据库连接池爆满如何排查
网络·数据库·oracle
百***81271 小时前
从 SQL 语句到数据库操作
数据库·sql·oracle
rchmin1 小时前
mysql中 char 和 varchar 的区别
数据库·mysql
SelectDB2 小时前
深入理解 Doris Variant:如何让 JSON 查询性能追平列存,还能承载万列索引字段?|Deep Dive
大数据·数据库·数据分析
百***3282 小时前
数据库(MySQL):使用命令从零开始在Navicat创建一个数据库及其数据表(一).创建基础表
数据库·mysql·oracle
optimistic_chen2 小时前
【Linux 系列】Linux 命令/快捷键详解
linux·运维·服务器·ubuntu·命令行·快捷键
q***d1732 小时前
SQL性能调优
数据库·sql
q***T5832 小时前
MySQL爬虫
数据库·爬虫·mysql
q***72564 小时前
【JOIN】关键字在MySql中的详细使用
数据库·mysql