承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

Linux教你怎样使用gdb调试core文件

管理员 2023-09-13 08:17:05 互联网圈 0 ℃ 0 评论 10939字 收藏

1.core文件

当程序运行进程中出现Segmentation fault (core dumped)毛病时,程序停止运行,并产生core文件。core文件是程序运行状态的内存映象。使用gdb调试core文件,可以帮助我们快速定位程序出现段毛病的位置。固然,可履行程序编译时应加上-g编译选项,生成调试信息。

当程序访问的内存超越了系统给定的内存空间,就会产生Segmentation fault (core dumped),因此,段毛病产生的情况主要有:

(1)访问不存在的内存地址;
(2)访问系统保护的内存地址;
(3)数组访问越界等。

core dumped又叫核心转储, 当程序运行进程中产生异常, 程序异常退出时, 由操作系统把程序当前的内存状态存储在一个core文件中, 叫core dumped。

core意指core memory,用线圈做的内存。如今 ,半导体工业澎勃发展,已没有人用 core memory 了,不过,在许多情况下,人们或者把记忆体叫作 core 。

2.控制core文件会不会生成

(1)使用ulimit -c命令可查看core文件的生成开关。若结果为0,则表示关闭了此功能,不会生成core文件。

(2)使用ulimit -c filesize命令,可以限制core文件的大小(filesize的单位为KB)。如果生成的信息超过此大小,将会被裁剪,终究生成一个不完全的core文件。在调试此core文 件的时候,gdb会提示毛病。比如:ulimit -c 1024。

(3)使用ulimit -c unlimited,则表示core文件的大小不受限制。

在终端通过命令ulimit -c unlimited只是临时修改,重启后无效 ,要想永久修改有三种方式:

(1)在/etc/rc.local 中增加一行 ulimit -c unlimited

(2)在/etc/profile 中增加一行 ulimit -c unlimited

(3)在/etc/security/limits.conf最后增加以下两行记录:

@root soft core unlimited
@root hard core unlimited

3.core文件的名称和生成路径

core默许的文件名称是core.pid,pid指的是产生段毛病的程序的进程号。
默许路径是产生段毛病的程序确当前目录。

如果想修改core文件的名称和生成路径,相关的配置文件为:
/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.gdb调试core文件的步骤

使用gdb调试core文件来查找程序中出现段毛病的位置时,要注意的是可履行程序在编译的时候需要加上-g编译命令选项。

gdb调试core文件的步骤常见的有以下几种,推荐第一种。

具体步骤一:

(1)启动gdb,进入core文件,命令格式:gdb [exec file] [core file]。
用法示例:gdb ./test test.core。

(2)在进入gdb后,查找段毛病位置:where或bt

用法示例:

可以定位到源程序中具体文件的具体位置,出现了段毛病。

具体步骤二:

(1)启动gdb,进入core文件,命令格式:gdb –core=[core file]。
用法示例:gdb –core=test.core。

(2)在进入gdb后,指定core文件对应的符号表,命令格式:file [exec file] .
用法示例:

具体步骤三:

(1)启动gdb,进入core文件,命令格式:gdb -c [core file]。
用法示例:gdb -core test.core。
(2)其它步骤同步骤二。

5.其它查找段毛病位置的方法

可使用gdb进行单步调试,来查找段毛病出错的位置。gdb的用例具体见:
Linux下gdb用法简单介绍。

1.core文件

当程序运行进程中出现Segmentation fault (core dumped)毛病时,程序停止运行,并产生core文件。core文件是程序运行状态的内存映象。使用gdb调试core文件,可以帮助我们快速定位程序出现段毛病的位置。固然,可履行程序编译时应加上-g编译选项,生成调试信息。

当程序访问的内存超越了系统给定的内存空间,就会产生Segmentation fault (core dumped),因此,段毛病产生的情况主要有:

(1)访问不存在的内存地址;
(2)访问系统保护的内存地址;
(3)数组访问越界等。

core dumped又叫核心转储, 当程序运行进程中产生异常, 程序异常退出时, 由操作系统把程序当前的内存状态存储在一个core文件中, 叫core dumped。

core意指core memory,用线圈做的内存。如今 ,半导体工业澎勃发展,已没有人用 core memory 了,不过,在许多情况下,人们或者把记忆体叫作 core 。

2.控制core文件会不会生成

(1)使用ulimit -c命令可查看core文件的生成开关。若结果为0,则表示关闭了此功能,不会生成core文件。

(2)使用ulimit -c filesize命令,可以限制core文件的大小(filesize的单位为KB)。如果生成的信息超过此大小,将会被裁剪,终究生成一个不完全的core文件。在调试此core文 件的时候,gdb会提示毛病。比如:ulimit -c 1024。

(3)使用ulimit -c unlimited,则表示core文件的大小不受限制。

在终端通过命令ulimit -c unlimited只是临时修改,重启后无效 ,要想永久修改有三种方式:

(1)在/etc/rc.local 中增加一行 ulimit -c unlimited

(2)在/etc/profile 中增加一行 ulimit -c unlimited

(3)在/etc/security/limits.conf最后增加以下两行记录:

@root soft core unlimited
@root hard core unlimited

3.core文件的名称和生成路径

core默许的文件名称是core.pid,pid指的是产生段毛病的程序的进程号。
默许路径是产生段毛病的程序确当前目录。

如果想修改core文件的名称和生成路径,相关的配置文件为:
/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.gdb调试core文件的步骤

使用gdb调试core文件来查找程序中出现段毛病的位置时,要注意的是可履行程序在编译的时候需要加上-g编译命令选项。

gdb调试core文件的步骤常见的有以下几种,推荐第一种。

具体步骤一:

(1)启动gdb,进入core文件,命令格式:gdb [exec file] [core file]。
用法示例:gdb ./test test.core。

(2)在进入gdb后,查找段毛病位置:where或bt

用法示例:

可以定位到源程序中具体文件的具体位置,出现了段毛病。

具体步骤二:

(1)启动gdb,进入core文件,命令格式:gdb –core=[core file]。
用法示例:gdb –core=test.core。

(2)在进入gdb后,指定core文件对应的符号表,命令格式:file [exec file] .
用法示例:

具体步骤三:

(1)启动gdb,进入core文件,命令格式:gdb -c [core file]。
用法示例:gdb -core test.core。
(2)其它步骤同步骤二。

5.其它查找段毛病位置的方法

可使用gdb进行单步调试,来查找段毛病出错的位置。gdb的用例具体见:
Linux下gdb用法简单介绍。

以上就是Linux教你怎样使用gdb调试core文件的详细内容,更多关于Linux gdb调试core文件的资料请关注其它相关文章!

文章来源:丸子建站

文章标题:Linux教你怎样使用gdb调试core文件

https://www.wanzijz.com/view/79353.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信