linux下生成core dump文件方法及设置【转】
转自:http://blog.csdn.net/mrjy1475726263/article/details/44116289
源自:http://andyniu.iteye.com/blog/1965571
core dump的概念:
A core dump is the recorded state of the working memory of a computer program at a specific time, generally when the program has terminated abnormally (crashed). In practice, other key pieces of program state are usually dumped at the same time, including the processor registers, which may include the program counter and stack pointer, memory management information, and other processor and operating system flags and information. The name comes from the once-standard memory technology core memory. Core dumps are often used to diagnose or debug errors in computer programs.
On many operating systems, a fatal error in a program automatically triggers a core dump, and by extension the phrase "to dump core" has come to mean, in many cases, any fatal error, regardless of whether a record of the program memory is created.
在linux平台下,设置core dump文件生成的方法:
如何产生Core Dump
发生doredump一般都是在进程收到某个信号的时候,Linux上现在大概有60多个信号,可以使用 kill -l 命令全部列出来。
sagi@sagi-laptop:~$ kill -l
1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP
6) SIGABRT 7) SIGBUS 8) SIGFPE 9) SIGKILL 10) SIGUSR1
11) SIGSEGV 12) SIGUSR2 13) SIGPIPE 14) SIGALRM 15) SIGTERM
16) SIGSTKFLT 17) SIGCHLD 18) SIGCONT 19) SIGSTOP 20) SIGTSTP
21) SIGTTIN 22) SIGTTOU 23) SIGURG 24) SIGXCPU 25) SIGXFSZ
26) SIGVTALRM 27) SIGPROF 28) SIGWINCH 29) SIGIO 30) SIGPWR
31) SIGSYS 34) SIGRTMIN 35) SIGRTMIN+1 36) SIGRTMIN+2 37) SIGRTMIN+3
38) SIGRTMIN+4 39) SIGRTMIN+5 40) SIGRTMIN+6 41) SIGRTMIN+7 42) SIGRTMIN+8
43) SIGRTMIN+9 44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+13
48) SIGRTMIN+14 49) SIGRTMIN+15 50) SIGRTMAX-14 51) SIGRTMAX-13 52) SIGRTMAX-12
53) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9 56) SIGRTMAX-8 57) SIGRTMAX-7
58) SIGRTMAX-6 59) SIGRTMAX-5 60) SIGRTMAX-4 61) SIGRTMAX-3 62) SIGRTMAX-2
63) SIGRTMAX-1 64) SIGRTMAX
针对特定的信号,应用程序可以写对应的信号处理函数。如果不指定,则采取默认的处理方式, 默认处理是coredump的信号如下:
3)SIGQUIT 4)SIGILL 6)SIGABRT 8)SIGFPE 11)SIGSEGV 7)SIGBUS 31)SIGSYS
5)SIGTRAP 24)SIGXCPU 25)SIGXFSZ 29)SIGIOT
我们看到SIGSEGV在其中,一般数组越界或是访问空指针都会产生这个信号。另外虽然默认是这样的,但是你也可以写自己的信号处理函数改变默认行为,更多信号相关可以看参考链接33。
上述内容只是产生coredump的必要条件,而非充分条件。要产生core文件还依赖于程序运行的shell,可以通过ulimit -a命令查看,输出内容大致如下:
sagi@sagi-laptop:~$ ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 20
file size (blocks, -f) unlimited
pending signals (-i) 16382
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) unlimited
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
看到第一行了吧,core file size,这个值用来限制产生的core文件大小,超过这个值就不会保存了。我这里输出是0,也就是不会保存core文件,即使产生了,也保存不下来==! 要改变这个设置,可以使用ulimit -c unlimited。
OK, 现在万事具备,只缺一个能产生Core的程序了,介个对C程序员来说太容易了。
- <span style="margin:0px;padding:0px;border:0px;color:rgb(51,153,51);vertical-align:baseline;background-color:transparent;">#include <stdio.h>;</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(51,153,51);vertical-align:baseline;background-color:transparent;">#include <stdlib.h>;</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(153,51,51);vertical-align:baseline;background-color:transparent;">int</span> crash<span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">(</span><span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">)</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">{</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(153,51,51);vertical-align:baseline;background-color:transparent;">char</span> <span style="margin:0px;padding:0px;border:0px;color:rgb(51,153,51);vertical-align:baseline;background-color:transparent;">*</span>xxx <span style="margin:0px;padding:0px;border:0px;color:rgb(51,153,51);vertical-align:baseline;background-color:transparent;">=</span> <span style="margin:0px;padding:0px;border:0px;color:rgb(255,0,0);vertical-align:baseline;background-color:transparent;">"crash!!"</span><span style="margin:0px;padding:0px;border:0px;color:rgb(51,153,51);vertical-align:baseline;background-color:transparent;">;</span>
- xxx<span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">[</span><span style="margin:0px;padding:0px;border:0px;color:rgb(0,0,221);vertical-align:baseline;background-color:transparent;">1</span><span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">]</span> <span style="margin:0px;padding:0px;border:0px;color:rgb(51,153,51);vertical-align:baseline;background-color:transparent;">=</span> <span style="margin:0px;padding:0px;border:0px;color:rgb(255,0,0);vertical-align:baseline;background-color:transparent;">'D'</span><span style="margin:0px;padding:0px;border:0px;color:rgb(51,153,51);vertical-align:baseline;background-color:transparent;">;</span> <span style="margin:0px;padding:0px;border:0px;color:rgb(102,102,102);font-style:italic;vertical-align:baseline;background-color:transparent;">// 写只读存储区!</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(177,177,0);vertical-align:baseline;background-color:transparent;">return</span> <span style="margin:0px;padding:0px;border:0px;color:rgb(0,0,221);vertical-align:baseline;background-color:transparent;">2</span><span style="margin:0px;padding:0px;border:0px;color:rgb(51,153,51);vertical-align:baseline;background-color:transparent;">;</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">}</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(153,51,51);vertical-align:baseline;background-color:transparent;">int</span> foo<span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">(</span><span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">)</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">{</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(177,177,0);vertical-align:baseline;background-color:transparent;">return</span> crash<span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">(</span><span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">)</span><span style="margin:0px;padding:0px;border:0px;color:rgb(51,153,51);vertical-align:baseline;background-color:transparent;">;</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">}</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(153,51,51);vertical-align:baseline;background-color:transparent;">int</span> main<span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">(</span><span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">)</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">{</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(177,177,0);vertical-align:baseline;background-color:transparent;">return</span> foo<span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">(</span><span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">)</span><span style="margin:0px;padding:0px;border:0px;color:rgb(51,153,51);vertical-align:baseline;background-color:transparent;">;</span>
- <span style="margin:0px;padding:0px;border:0px;color:rgb(0,153,0);vertical-align:baseline;background-color:transparent;">}</span>
上手调试
|
1
2
3
4
5
6
7
8
9
10
11
12
|
#include <stdio.h>int func(int*p){ *p = 0;}int main(){ func(NULL); return0;} |
Segmentation fault (core dumped)
#0 0x080483ba in func ()
如何定位到行?
main /tmp/core-main-10815
#0 0x080483ba in func (p=0x0) at a.c:5
5 *p = 0;
-c unlimited
"/tmp/core-%e-%p" > /proc/sys/kernel/core_pattern
上边的程序编译的时候有一点需要注意,需要带上参数-g,
这样生成的可执行程序中会带上足够的调试信息。编译运行之后你就应该能看见期待已久的“Segment Fault(core
dumped)”或是“段错误
(核心已转储)”之类的字眼了。看看当前目录下是不是有个core或是core.xxx的文件。祭出linux下经典的调试器GDB,首先带着core文件载入程序:gdb
exefile core,这里需要注意的这个core文件必须是exefile产生的,否则符号表会对不上。载入之后大概是这个样子的:
sagi@sagi-laptop:~$ gdb coredump core
Core was generated by ./coredump'.
Program terminated with signal 11, Segmentation fault.
#0 0x080483a7 in crash () at coredump.c:8
8 xxx[1] = 'D';
(gdb)
我们看到已经能直接定位到出core的地方了,在第8行写了一个只读的内存区域导致触发Segment Fault信号。在载入core的时候有个小技巧,如果你事先不知道这个core文件是由哪个程序产生的,你可以先随便找个代替一下,比如/usr/bin/w就是不错的选择。比如我们采用这种方法载入上边产生的core,gdb会有类似的输出:
sagi@sagi-laptop:~$ gdb /usr/bin/w core
Core was generated by ./coredump'.
Program terminated with signal 11, Segmentation fault.
#0 0x080483a7 in ?? ()
(gdb)
可以看到GDB已经提示你了,这个core是由哪个程序产生的。
GDB 常用操作
上边的程序比较简单,不需要另外的操作就能直接找到问题所在。现实却不是这样的,常常需要进行单步跟踪,设置断点之类的操作才能顺利定位问题。下边列出了GDB一些常用的操作。
- 启动程序:run
- 设置断点:b 行号|函数名
- 删除断点:delete 断点编号
- 禁用断点:disable 断点编号
- 启用断点:enable 断点编号
- 单步跟踪:next 也可以简写 n
- 单步跟踪:step 也可以简写 s
- 打印变量:print 变量名字
- 设置变量:set var=value
- 查看变量类型:ptype var
- 顺序执行到结束:cont
- 顺序执行到某一行: util lineno
- 打印堆栈信息:bt
linux下生成core dump文件方法及设置【转】的更多相关文章
- linux下生成core dump文件方法及设置
linux下生成core dump文件方法及设置 from:http://www.cppblog.com/kongque/archive/2011/03/07/141262.html core ...
- linux下生成core dump文件方法
core 文件的简单介绍 当程序运行的过程中异常终止或崩溃,操作系统会将程序当时的内存状态记录下来,保存在一个文件中,这种行为就叫做Core Dump(中文有的翻译成“核心转储”).我们可以认为 co ...
- 解决linux下不生成core dump文件
core dump的概念: A core dump is the recorded state of the working memory of a computer program at a spe ...
- Ubuntu16.04下写的Qt程序,调试时没问题,运行时偶现崩溃 (需要在运行时生成core dump文件,QMAKE_CC += -g)
记录一下 Ubuntu16.04下写的Qt程序,调试时没问题,运行时偶现崩溃 需要在运行时生成core dump文件 首先在pro结尾里加入 QMAKE_CC += -g QMAKE_CXX += - ...
- Linux中生成Core Dump系统异常信息记录文件的教程
Linux中生成Core Dump系统异常信息记录文件的教程 http://www.jb51.net/LINUXjishu/473351.html
- linux下恢复误删除的文件方法(ext2及ext3)
linux下恢复误删除的文件方法(ext2及ext3) 2009-12-19 15:23:47 分类: LINUX 如果是ext2文件系统的,直接用debugfs是可以恢复出来的,但对于ext3,d ...
- core dump使用方法、设置、测试用例
core dump使用方法.设置.测试用例 http://blog.csdn.net/liuzhuchen/article/details/21975227
- dotnet core调试docker下生成的dump文件
最近公司预生产环境.net core应用的docker容器经常出现内存暴涨现象,有时会突然吃掉几个G,触发监控预警,造成容器重启. 分析了各种可能原因,修复了可能发生的内存泄露,经测试本地正常,但是发 ...
- vs 自动生成core dump文件
一直以来觉着core dump这个东西很神奇,在初步学习的时候也没有个大方向,最近项目需要记录程序崩溃时的日志信息,因此在网上寻找相关的信息,此时core dump也成为了我重点关注的东西. 说说我的 ...
随机推荐
- luogu 1066 引水入城(bfs+贪心)
90分,有一个点TLE.... 首先可以证明一个东西,如果从上面一排的某个点bfs一次到最下面一排的饮水点不是一个区间的话,那么最后一定所有饮水点不会被覆盖完的. 证明考虑反证法. 所以从上面一排的每 ...
- Java开发Excel POI getPhysicalNumberOfCells 与 getLastCellNum的区别
1.getPhysicalNumberOfCells 与 getLastCellNum的区别 用org.apache.poi的包做excel导入,无意间发明若是excel文件中有空列,空列后面的数据全 ...
- 【刷题】BZOJ 1036 [ZJOI2008]树的统计Count
Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成 一些操作: I. CHANGE u t : 把结点u的权值改为t II. ...
- C之Volatile关键字的介绍与使用20170724
volatile 的意思是“易失的,易改变的”. 一.volatile的引入 这个限定词的含义是向编译器指明变量的内容可能会由于其他程序的修改而变化.通常在程序中申明了一个变量时,编译器会尽量把它存放 ...
- ss命令用法小记
By francis_hao Nov 4,2017 ss是一个查看socket的实用工具 概要 ss [options] [ FILTER ] 描述 ss可以查看socket的统计信息, ...
- python学习笔记(三)高级特性
一.切片 list.tuple常常截取某一段元素,截取某一段元素的操作很常用 ,所以python提供了切片功能. L=['a','b','c','d','e','f'] #取索引0,到索引3的元素,不 ...
- 简单的并发服务器(多个线程各自accept)
基于之前讲述的简单循环服务器,做一个多个线程各自accept的服务器demo 由于多个线程各自accept,容易造成数据错误,需要在accept前后枷锁 先看下客户端 客户端创建socket,初始化服 ...
- 前端PHP入门-023-重点日期函数之程序执行时间检测
我们有的时经常需要做程序的执行时间执行效率判断. 实现的思路如下: <?php //记录开始时间 //记录结整时 // 开始时间 减去(-) 结束时间 得到程序的运行时间 ?> 可是大家不 ...
- python---爬虫相关性能(各个异步模块的使用,和自定义异步IO模块)
一:线程池,进程池等相关文章了解 python---基础知识回顾(十)进程和线程(py2中自定义线程池和py3中的线程池使用) python---基础知识回顾(十)进程和线程(协程gevent:线程在 ...
- 使用HttpClient4来构建Spring RestTemplate
Spring RestTemplate简单说明 现在REST服务已经很普及了,在我们的程序中,经常会需要调用REST API,这时候会有很多选择,原始一点的JDK自带的,再进一步点使用HttpClie ...