执行文件编译时加入-g 命令

例如 g++ -g test.cpp

查看当前系统限制情况

ulimit -a

SRE实战 互联网时代守护先锋,助力企业售后服务体系运筹帷幄!一键直达领取阿里云限量特价优惠。

设置crash dump 文件大小

ulimit -c unlimited 
unlimited表示无大小限制,也可以指定具体的大小 
ulimit -c 1000 
表示文件大小限制为1000Kb 
若要全局生效需要在/etc/profile中加入上面的命令ulimit -c 1000,然后source /etc/profile使之生效

配置dump文件生成路径

/proc/sys/kernel/core_uses_pid 
文件内容为1表示dump文件以pid为扩展名 
/proc/sys/kernel/core_pattern 
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” > /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为#后的数字

扫码关注我们
微信号:SRE实战
拒绝背锅 运筹帷幄