今天尝试core dump功能调试,发现一直没法生成崩溃dump文件
代码如下:
#include"iostream"
using namespace std;
int main(){
int a = 10;
//cin>>a;
int b = 0;
cout << a << b << endl;
int c = a/b;
cout<<a/b<<endl;
system("pause");
return 0;
}
尝试方法:
core dump文件大小设置成10000个block(通过指令ulimit -c 10000)
ulimit -c unlimited 可以设置core dump文件大小不限制;(只在当前shell有效)
修改vim ~/.bashrc,添加: ulimit -c unlimited,使生效:source ~/.bashrc
查看dump文件存放目录是否在当前目录下
查看dump文件处理方式:cat /proc/sys/kernel/core_pattern
默认输出:| /usr/share/apport/apport -p%p -s%s -c%c -d%d -P%P -u%u -g%g -- %E,最前面的管道'|'即将dump出来的文件给到脚本处理,所以不会对崩溃文件做存储;
以下是参数列表:
%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 添加命令名
需要执行:echo /data/coredump/core.%e.%p> /proc/sys/kernel/core_pattern,将崩溃文件存储到/data/coredump文件夹下面,如果没有这个文件夹需要手动创建;
如果再运行执行文件的时候还是没有生成core dump文件,尝试切换到root权限下运行;
在root权限下,也需要修改vim ~/.bashrc,添加: ulimit -c unlimited,使生效:source ~/.bashrc
exit退出root权限;
再运行执行文件时,就看到/data/coredump 文件夹下看到生成的dump文件
软件重启时,又出现不能生成core dump文件的现象
发现是core的生成路径(/proc/sys/kernel/core_pattern里的内容)又被篡改为
|/usr/share/apport/apport -p%p -s%s -c%c -d%d -P%P -u%u -g%g -- %E
原因是因为第二步的修改只是对此次系统运行生效,重启后会被修改(具体原因还没搞明白)
解决方法:
再次执行步骤2;
修改/etc/sysctl.conf配置文件,添加文章来源:https://www.toymoban.com/news/detail-698630.html
kernel.core_pattern=core-%e-%p-%t
kernel.core_uses_pid=1
下次电脑重启时,这个内容不会被修改,但是/proc/sys/kernel/core_pattern里的内容还是会被修改,需要 再次执行 sysctl -p 即可;文章来源地址https://www.toymoban.com/news/detail-698630.html
到了这里,关于linux不生成core dump文件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!