嵌入式Linux如何生成Core Dump文件

  • 测试环境
    • 开发板:致远电子EPC-9600-V2.06
    • 开发环境:DeepIn15.11
    • 开发语言:C语言
    • 测试软件:Final Shell3.0.10
  • 目录
    • 分清你的程序是前台运行还是后台运行,二者有何区别
    • 前台运行和后台运行的区别
    • 前后台程序生成core dump时有何区别
    • 前台进程如何生成core dump
    • 后台进程如何生成core dump
  • 正文
  • 分清你的程序是前台运行还是后台运行,二者有何区别
    • 前台进程:一般而言,用户在shell中使用./执行的程序都是前台程序,前台程序可由用户自己控制,程序运行过程中可与用户进行交互,其运行优先级相比后台程序稍高,前台程序运行过程中用户可使用ctrl+c来终止
    • 后台进程:后台进程又叫守护进程,是运行在系统后台的一种特殊进程,它独立于控制终端并且周期性地执行某种任务或等待处理某些发生的事件,后台进程最大的特点就是不受终端控制。一般用作系统服务,比如日志管理进程rsyslogd,数据库服务myspld等,当然也有一些用户程序因需要被放在后台运行,一般被放在/etc/ini.d/文件夹中设置开机自启动
  • 前后台程序生成core dump时有何区别
    • 我们在生成core dump时一般先使用ulimit -c 来开启系统限制,然后再配置/proc/sys/kernel/core_pattern设定core dump文件的生成路径。
    • 但是ulimit命令是有作用范围的,事实上ulimit限制的是当前shell进程以及其派生的子进程,所以通过ulimit修改coresize只是针对在当前shell下启动的子进程,而不能影响其他shell下启动的进程。
    • 所以当我们配置完成生成core dump的参数后,在当前shell直接执行的进程发生崩溃时可以正常生成core,而后台开机自启动的程序则无法生成,而对于被用于工业控制的嵌入式板,应用程序一般都是开机自启动的,并且发送崩溃的时机也是不可预测的,那么使用这种方式就不能正确的去捕捉coredump文件了
    • 前台进程如何生成core dump
      • 如上文所说,前台程序想要生成core dump文件,只需在程序运行之前配置好core dump相关设定即可
        • uliimit -c unlimit //开启core 生成,并不对生成core文件大小进行限制
        • 嵌入式Linux如何生成Core Dump文件_第1张图片

        • echo "/media/mmcblk0p1/%e-%t.coredump" > /proc/sys/kernel/core_pattern //设置文件保存路径以及文件名
    • 后台进程如何生成core dump
      • 后台进程要生成core dump文件需在进程代码中开启core dump功能,可调用setrlimit函数来实现对coresize参数的设置,所以在调试后台程序时只需在程序中添加以下代码段开启core dump功能即可(文件生成地址可自行修改)
      • static int enableCoreDumpFunc(){
        	int iRes = RLIMIT_CORE;
        	struct rlimit limitParam;
        	limitParam.rlim_cur = 1 ? RLIM_INFINITY : 0;
        	limitParam.rlim_max = 1 ? RLIM_INFINITY : 0;
        	if(0 != setrlimit(iRes,&limitParam)){
        		printf("Error: setrlimit failed, %s\n", strerror(errno));
        		return 0;
        	}else{
        		system("echo /media/mmcblk0p1/%e-%t-%s.coredump > /proc/sys/kernel/core_pattern");
        		printf("Set coredump file size to %lu, path = /var/core\n",limitParam.rlim_cur);		
        		return 1;
        	}
        	return 0;
        }

         

      • 最后在main函数中调用此函数即可开启core dump

你可能感兴趣的:(Linux)