(转)Linux core 文件介绍与处理

1. core文件的简单介绍
在一个程序崩溃时,它一般会在指定目录下生成一个core文件。core文件仅仅是一个内存映象(同时加上调试信息),主要是用来调试的。

2. 开启或关闭core文件的生成
用以下命令来阻止系统生成core文件:
ulimit -c 0
下面的命令可以检查生成core文件的选项是否打开:
ulimit -a
该命令将显示所有的用户定制,其中选项-a代表“all”。

也可以修改系统文件来调整core选项
在/etc/profile通常会有这样一句话来禁止产生core文件,通常这种设置是合理的:
# No core files by default
ulimit -S -c 0 > /dev/null 2>&1
但是在开发过程中有时为了调试问题,还是需要在特定的用户环境下打开core文件产生的设置
在用户的~/.bash_profile里加上ulimit -c unlimited来让特定的用户可以产生core文件
如果ulimit -c 0 则也是禁止产生core文件,而ulimit -c 1024则限制产生的core文件的大小不能超过1024kb

3. 设置Core Dump的核心转储文件目录和命名规则
/proc/sys/kernel/core_uses_pid可以控制产生的core文件的文件名中是否添加pid作为扩展,如果添加则文件内容为1,否则为0
/proc/sys/kernel/core_pattern可以设置格式化的core文件保存位置或文件名,比如原来文件内容是core-%e
可以这样修改:
echo "/corefile/core-%e-%p-%t" > /proc/sys/kernel/core_pattern
将会控制所产生的core文件会存放到/corefile目录下,产生的文件名为core-命令名-pid-时间戳
以下是参数列表:
    %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 添加命令名

4. 使用core文件
在core文件所在目录下键入:
gdb -c core
它会启动GNU的调试器,来调试core文件,并且会显示生成此core文件的程序名,中止此程序的信号等等
如果你已经知道是由什么程序生成此core文件的,比如MyServer崩溃了生成core.12345,那么用此指令调试:
gdb -c core MyServer
以下怎么办就该去学习gdb的使用了

5. 一个小方法来测试产生core文件
直接输入指令:
kill -s SIGSEGV $$

6. 为何有时程序Down了,却没生成 Core文件。

Linux下,有一些设置,标明了resources available to the shell and to processes。 可以使用

#ulimit -a 来看这些设置。 (ulimit是bash built-in Command)

             -a     All current limits are reported
              -c     The maximum size of core files created
              -d     The maximum size of a process
鈥檚 data segment
              -e     The maximum scheduling priority ("nice")
              -f     The maximum size of files written by the shell and its children
              -i     The maximum number of pending signals
              -l     The maximum size that may be locked into memory
              -m     The maximum resident set size (has no effect on Linux)
              -n     The maximum number of open file descriptors (most systems do not allow this value to be set)
              -p     The pipe size in 512-byte blocks (this may not be set)
              -q     The maximum number of bytes in POSIX message queues
              -r     The maximum real-time scheduling priority
              -s     The maximum stack size
              -t     The maximum amount of cpu time in seconds
              -u     The maximum number of processes available to a single user
              -v     The maximum amount of virtual memory available to the shell
              -x     The maximum number of file locks

从这里可以看出,如果 -c是显示:core file size          (blocks, -c)

如果这个值为0,则无法生成core文件。所以可以使用:

#ulimit -c 1024 或者 #ulimit -c unlimited 来使能 core文件。

如果程序出错时生成Core 文件,则会显示Segmentation fault (core dumped)

7. Core Dump的核心转储文件目录和命名规则:
/proc/sys/kernel/core_uses_pid可以控制产生的core文件的文件名中是否添加pid作为扩展,如果添加则文件内容为1,否则为0

 8.反推应用名字和相关信息

1.ps -ef|grep bpe/hps 看进程的重启时间

[root]# ps -ef|grep hps
root 1966 1 0 Jan19 ? 00:00:00 ./hps
root 1968 1966 0 Jan19 ? 1-11:31:36 ./hps
root 8251 1 0 Jul23 ? 00:00:00 ./hps
root 8253 8251 0 Jul23 ? 02:33:17 ./hps
root 9225 1 0 Mar26 ? 00:00:00 ./hps
root 9227 9225 0 Mar26 ? 16:17:26 ./hps
root 11778 1 0 Mar17 ? 00:00:00 ./hps
root 11780 11778 0 Mar17 ? 10:03:21 ./hps
root 14555 1 0 Jul14 ? 00:00:00 ./hps
root 14557 14555 12 Jul14 ? 3-08:21:30 ./hps
root 17573 1 0 May21 ? 00:00:00 ./hps
root 17575 17573 0 May21 ? 02:35:42 ./hps
root 18754 1 0 Apr02 ? 00:00:00 ./hps
root 18756 18754 0 Apr02 ? 04:33:11 ./hps
root 21221 1 0 Aug06 ? 00:00:00 ./hps
root 21223 21221 14 Aug06 ? 13:39:10 ./hps
root 24987 1 0 13:45 pts/1 00:00:00 ./hps
root 24989 24987 12 13:45 pts/1 00:06:55 ./hps
root 27844 20840 0 14:40 pts/3 00:00:00 grep hps
root 31568 1 0 Apr09 ? 00:00:00 ./hps
root 31570 31568 1 Apr09 ? 1-17:20:24 ./hps

2.通过进程号 ll /proc/ 查看应用

[root]# ll /proc/24987
total 0
dr-xr-xr-x 2 root root 0 Aug 10 14:12 attr
-r-------- 1 root root 0 Aug 10 14:12 auxv
-r--r--r-- 1 root root 0 Aug 10 13:45 cmdline
-rw-r--r-- 1 root root 0 Aug 10 14:12 coredump_filter
-r--r--r-- 1 root root 0 Aug 10 14:12 cpuset
lrwxrwxrwx 1 root root 0 Aug 10 14:12 cwd -> /opt/app/hps4gauth
-r-------- 1 root root 0 Aug 10 14:12 environ
lrwxrwxrwx 1 root root 0 Aug 10 14:12 exe -> /opt/app/hps4gauth/hps
dr-x------ 2 root root 0 Aug 10 13:45 fd
dr-x------ 2 root root 0 Aug 10 14:12 fdinfo
-r-------- 1 root root 0 Aug 10 14:12 io
-r--r--r-- 1 root root 0 Aug 10 14:12 limits
-rw-r--r-- 1 root root 0 Aug 10 14:12 loginuid
-r--r--r-- 1 root root 0 Aug 10 14:12 maps
-rw------- 1 root root 0 Aug 10 14:12 mem
-r--r--r-- 1 root root 0 Aug 10 13:45 mounts
-r-------- 1 root root 0 Aug 10 14:12 mountstats
-r--r--r-- 1 root root 0 Aug 10 14:12 numa_maps
-rw-r--r-- 1 root root 0 Aug 10 14:12 oom_adj
-r--r--r-- 1 root root 0 Aug 10 14:12 oom_score
lrwxrwxrwx 1 root root 0 Aug 10 14:12 root -> /
-r--r--r-- 1 root root 0 Aug 10 14:12 schedstat
-r--r--r-- 1 root root 0 Aug 10 14:12 smaps
-r--r--r-- 1 root root 0 Aug 10 13:45 stat
-r--r--r-- 1 root root 0 Aug 10 13:46 statm
-r--r--r-- 1 root root 0 Aug 10 13:45 status
dr-xr-xr-x 3 root root 0 Aug 10 14:12 task
-r--r--r-- 1 root root 0 Aug 10 14:12 wchan

这估计是所能找到的最好的方法了…………。

时间: 2024-10-12 19:15:02

(转)Linux core 文件介绍与处理的相关文章

Linux core 文件介绍

Linux core 文件介绍 http://www.cnblogs.com/dongzhiquan/archive/2012/01/20/2328355.html 1. core文件的简单介绍在一个程序崩溃时,它一般会在指定目录下生成一个core文件.core文件仅仅是一个内存映象(同时加上调试信息),主要是用来调试的. 2. 开启或关闭core文件的生成用以下命令来阻止系统生成core文件:ulimit -c 0下面的命令可以检查生成core文件的选项是否打开:ulimit -a该命令将显示

linux core文件设置

http://blog.csdn.net/ctthuangcheng/article/details/8963551 linux core文件设置 分类: Linux OS Debugging Technique2013-05-23 09:51 1446人阅读 评论(0) 收藏 举报 在Linux中,一般当进程非正常退出时,会生成一个core文件,这个文件是进程猝死时内存的转储文件,也称为core dump. 查看Linux脚本解析方式: echo $0 1.检验core是否打开 以see/se

core文件介绍

1. core文件的简单介绍在一个程序崩溃时,它一般会在指定目录下生成一个core文件.core文件仅仅是一个内存映象(同时加上调试信息),主要是用来调试的. 2. 开启或关闭core文件的生成用以下命令来阻止系统生成core文件:ulimit -c 0下面的命令可以检查生成core文件的选项是否打开:ulimit -a该命令将显示所有的用户定制,其中选项-a代表"all". 也可以修改系统文件来调整core选项在/etc/profile通常会有这样一句话来禁止产生core文件,通常这

linux core文件调试

在完成公司项目,测试进程的时候,经常会发现日志到了某一段特定的代码的时候就没了,进程直接退出,也没有捕获到任何的异常信息,如果日志打印的较多还可能比较容易发现问题,如果日志较少,就很难进行进一步的查错了. 但是发现在该目录下生成了一个core文件,可以帮助我们查找程序崩溃的原因. 1. 什么是core文件 在linux系统下,如果进程不能正常运行,就可能会产生core文件.core文件就是当前内存状态的一个映像,同时加上一些调试信息. bug和操作系统或硬件的保护机制都会导致程序异常终止,操作系

Linux core 文件

http://blog.csdn.net/mr_chenping/article/details/13767609 在程序不寻常退出时,内核会在当前工作目录下生成一个core文件(是一个内存映像,同时加上调试信息).使用gdb来查看core文件,可以指示出导致程序出错的代码所在文件和行数. 1.core文件的生成开关和大小限制 --------------------------------- 1)使用ulimit -c命令可查看core文件的生成开关.若结果为0,则表示关闭了此功能,不会生成c

用gdb分析core文件及常见gdb命令操作示例

1.概述 在实际的软件开发项目中,程序出现问题是在所难免的.遥想本人参加工作之后首次遇到程序的情景,至今还历历在目.之前的经验告诉我,我们越是惊慌失措,问题就越是解决不了.我们要先让自己平静下来,然后再寻找解决程序问题的办法. 在Linux下做开发的朋友,想必都与core文件打过交道.当看到自己的程序运行之后出现core时,很多人都慌乱了,仿佛天快要塌下来一样.其实,我们大可不必如此,只要我们掌握了用gdb调试core文件的办法,依然可以很快定位程序问题,一举将bug消灭掉.有关Linux co

Linux 系统设置 ulimit 以及 Core文件的生成

查看限制情况 ulimit -a 可以看到如下信息 core file size           (blocks, -c) 0data seg size            (kbytes, -d) unlimitedfile size                (blocks, -f) unlimitedpending signals                  (-i) 1024max locked memory        (kbytes, -l) 32max memor

linux设备驱动程序该添加哪些头文件以及驱动常用头文件介绍(转)

原文链接:http://blog.chinaunix.net/uid-22609852-id-3506475.html 驱动常用头文件介绍 #include <linux/***.h> 是在linux-2.6.29/include/linux下面寻找源文件.#include <asm/***.h> 是在linux-2.6.29/arch/arm/include/asm下面寻找源文件.#include <mach/***.h> 是在linux-2.6.29/arch/ar

Linux C程序异常退出怎么办——core文件帮你忙

想必你一定遇到过Linux下程序异常退出的问题,异常退出貌似有一种神奇的魔力,会让你神经突然紧张.不要怕,Linux是很强大的,在程序退出的时候,会在可执行文件所在的目录生成一个core文件,它很好地记录了一些神秘而又必要的东西,帮助你定位到错误的根源,想想以前面试的时候人家闻到core文件,我答不上来,你说面试官会怎样想,那么就来说说core文件. core文件实际上就是一个内存映象同时加上一些调试信息. 首先,你得打开系统的core文件生成开关吧,终端中输入ulimit -c命令,若显示0表