码迷,mamicode.com
首页 > 其他好文 > 详细

coredump

时间:2015-08-16 10:39:32      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:

coredump介绍

    应用程序有时会因为异常或者bug导致在运行过程中异常退出或者终止,为了方便问题的定位,我们往往需要获取程序运行时的内存,寄存器状态,堆栈指针,内存管理以及函数调用堆栈信息等,从而找到bug所在。在linux系统中,我们通常可以通过对系统进行一些配置,将上述的信息输出到ELF文件中,即core文件。

coredump详细介绍

    core文件默认存储位置与对应的可执行程序位于同一路径下,文件名为core;具体信息可以通过如下命令查看:

   cat /proc/sys/kernel/core_pattern

   如果程序中调用了chdir函数,则core文件生成在chdir指定路径下。另外,我们也可以通过相关设置设定core文件生成路径。

   在类unix系统中,core文件本身的主要格式也是ELF格式,因此可以使用readelf或者file命令查看core文件的具体信息。

coredump基本配置

    调试coredump文件需要读取相应符号信息,因此,编译时需要加入-g选项。

    系统资源限制,默认情况下,core文件大小限制为0,不会生成core文件,需要进行设置。命令如下:

        ulimit –c unlimited  (coredump文件大小不受限制)

    进程资源限制,有时即使系统设置了unlimited,但是当前进程启动时如果没有读取到,则仍然不会生成core文件。进程限制内容查看命令:

        egrep “Units|core” /proc/<pid>/limits

    使core文件添加pid信息

        echo “1” > /proc/sys/kernel/core_user_pid

    配置core文件位置和文件名格式

         echo “./core.%p.%e”> /proc/sys/kernel/core_pattern

          生成的core文件与执行程序位于相同路径,文件名为core.pid.execute_name

          其他控制参数:

               %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 添加命令名

    检查core目录,core文件生成路径所在磁盘空间是否为0,或者小于进程运行时所占的虚拟内存大小(通过top命令查看VIRT)

    检查core目录是否有写权限

    如果core文件没有core全,检查进程如下配置

        cat /proc/<pid>/coredump_filter

        00000003

        echo “0xF”> /proc/<pid>/coredump_filter

        原理如下:

             (bit 0) anonymous private memory

             (bit 1) anonymous shared memory

             (bit 2) file-backed privated memory

             (bit 3) file-backed shared memory

       如果发现core文件不知道属于哪个进程,执行如下命令:

            strings core.6440 | head

参考资料

详解coredump

coredump

标签:

原文地址:http://www.cnblogs.com/zhouLee/p/4733642.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!