天天看点

记录linux 生成crash dump文件步骤

例如 ​<code>​g++ -g test.cpp​</code>​

​<code>​ulimit -a​</code>​

​<code>​ulimit -c unlimited​</code>​ 

unlimited表示无大小限制,也可以指定具体的大小 

​<code>​ulimit -c 1000​</code>​ 

表示文件大小限制为1000Kb 

若要全局生效需要在​<code>​/etc/profile​</code>​中加入上面的命令​<code>​ulimit -c 1000​</code>​,然后​<code>​source /etc/profile​</code>​使之生效

​<code>​/proc/sys/kernel/core_uses_pid​</code>​ 

文件内容为1表示dump文件以pid为扩展名 

​<code>​/proc/sys/kernel/core_pattern​</code>​ 

core_pattern接受的是core文件名称的pattern,它包含任何字符串,并且用%作为转移符号生成一些标示符,为core文件名称加入特殊含义。已定义的标示符有如下这些: 

%%:相当于% 

%p:相当于pid 

%u:相当于uid 

%g:相当于gid 

%s:相当于导致dump的信号的数字 

%t:相当于dump的时间 

%e:相当于执行文件的名称 

%h:相当于hostname 

除以上这些标志位外,还规定: 

1、末尾的单个%可以直接去除; 

2、%加上除上述以外的任何字符,%和该字符都会被去除; 

3、所有其他字符都作为一般字符加入名称中; 

4、core文件的名称最大值为64个字节(包括’\0’); 

5、core_pattern中默认的pattern为core; 

6、为了保持兼容性,通过设置core_uses_pid,可以在core文件的末尾加上%p; 

7、pattern中可以包含路径信息。 

echo “/corefile/core-%e-%p-%t” &gt; /proc/sys/kernel/core_pattern 

将会控制所产生的core文件会存放到/corefile目录下(/corefile目录需要提前创建),产生的文件名为core-执行文件名-pid-时间戳

在发生SIGSEGV时系统会自动在程序目录下生成core.xxxx文件,此即dump文件; 

注意,此时程序不能再注册SIGSEGV的处理函数! 

使用gdb分析dump文件: 

1.执行gdb:gdb –core=core.xxxx 

2.在gdb中加载符号文件:file ./a.out 

上两步也可以统一成:gdb a.out core.xxxx 

3.定位到出错代码:where或backtrace,将显示#x这样的堆栈信息 

4.查看更详细的函数调用信息:frame x,x为#后的数字

作者:柒月

继续阅读