本文主要是介绍Core文件的生成和GDB调试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
一、什么是core文件?
有问题的程序运行后,产生“段错误 (核心已转储)”时生成的具有堆栈信息和调试信息的文件,我们可以理解为是程序在当前工作状态存储生成的第一个文件,许多的程序出错的时候都会产生一个core文件,通过工具分析core文件,我们可以定位到程序异常退出的时候对应的堆栈调用等信息,找出问题所在并进行及时解决。编译程序时需要加 -g 选项使程序生成调试信息: gcc -g test.c -o test
二、怎样配置生成 core 文件
1、core文件开关
- 使用 ulimit -c 查看core开关,如果为0表示关闭,不会生成core文件;
sl:02$ ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 31664
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 31664
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
sl:02$
-
使用 ulimit -c [filesize] 设置core文件大小,当最小设置为4之后才会生成core文件;
-
使用 ulimit -c unlimited 设置core文件大小为不限制,这是常用的做法;
#-> ulimit -a
core file size (blocks, -c) unlimited
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 3366
max locked memory (kbytes, -l) 64
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 3366
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
#->
- 如果需要开机就执行,则需要将这句命令写到 /etc/profile 等文件。
# Dump core files by default
ulimit -c unlimited
2、core文件命名和保存路径
-
core文件有默认的名称和路径,但为了方便,我们通常会自己命名和指定保存路径;
-
可以通过 /proc/sys/kernel/core_pattern 设置 core 文件名和保存路径,方法如下:
#-> cat /proc/sys/kernel/core_pattern
|/bin/coredumper %e %p %t
#-> echo "/corefile/core-%e-%p-%t" > /proc/sys/kernel/core_pattern
命名的参数列表:
%p - insert pid into filename 添加pid
%u - insert current uid into filename 添加当前uid
%g - insert current gid into filename 添加当前gid
%s - insert signal that caused the coredump into the filename 添加导致产生core的信号
%t - insert UNIX time that the coredump occurred into filename 添加core文件生成时的unix时间
%h - insert hostname where the coredump happened into filename 添加主机名
%e - insert coredumping executable name into filename 添加命令名。
三、调试core文件
这篇关于Core文件的生成和GDB调试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!