linux core指的是什么

68次阅读
没有评论

共计 3201 个字符,预计需要花费 9 分钟才能阅读完成。

这篇文章主要介绍“linux core 指的是什么”的相关知识,丸趣 TV 小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“linux core 指的是什么”文章能帮助大家解决问题。

在 linux 中,Core 是内存的意思。当程序运行过程中检测到异常程序异常退出时, 系统把程序当前的内存状况存储在一个 core 文件中, 叫 core dumped,也就信息转储;操作系统检测到当前进程异常时将通过信号的方式通知目标进程相应的错误信息,常见的信号有 SIGSEGV、SIGBUS 等,默认情况下进程接收到相应的信号都有相应的处理机制。

在 Linux 下开发中,我们经常听到程序员说我的程序 core 掉了,通常出现这类的问题是低级 bug 中的内存访问越界、使用空指针、堆栈溢出等情况。使程序运行过程中异常退出或者终止,满足这些条件就会产生 core 的文件。

为什么会发生 Coredump

Core 就是内存的意思,这个词源自很早以前制造内存的材料,一直延用到现在,当程序运行过程中检测到异常程序异常退出时, 系统把程序当前的内存状况存储在一个 core 文件中, 叫 core dumped,也就信息转储,操作系统检测到当前进程异常时将通过信号的方式通知目标进程相应的错误信息,常见的信号有 SIGSEGV,SIGBUS 等,默认情况下进程接收到相应的信号都有相应的处理机制。

以 Linux 为例,Action 则对应信号的处理方式,红色框标注为常见信号

在此之前最好先了解下进程的内存布局,Unix 与 Linux 系统的进程空间布局会稍微有点不同,内核空间会比 Linux 小,特别是内核与用户进程采用分离的地址空间模式,这里以 Linux 为例:

coredump 文件的存储位置

我们知道在 Linux 系统中,如果进程崩溃了,系统内核会捕获到进程崩溃信息,然后将进程的 coredump   信息写入到文件中,这个文件名默认是 core  。存储位置与对应的可执行程序在同一目录下,文件名是 core,大家可以通过下面的命令看到 core 文件的存在位置:

Core_pattern 的格式:

%p   转储过程的 PID
%u  (数字)转储进程的实际 UID
%G  (数字)转储过程的实际 GID
%s   引起转储的信号数
%t   转储时间,表示为自 1970 年 1 月 1 日 00:00:00 +0000(UTC)以来的秒数
%H   主机名(与 uname(2)返回的节点名相同)
%e   可执行文件名(无路径前缀)
%E   可执行文件的路径名,用斜杠(’/’)替换为感叹号(’!’)。
%C   崩溃过程的核心文件大小软资源限制(自 Linux 2.6.24 开始)

下面的程序可用于演示 / proc / sys / kernel / core_pattern 文件中管道语法的用法。

#include  sys/stat.h 
#include  fcntl.h 
#include  limits.h 
#include  stdio.h 
#include  stdlib.h 
#include  unistd.h 
#define BUF_SIZE 1024
int main(int argc, char *argv[])
 int tot, j;
 ssize_t nread;
 char buf[BUF_SIZE];
 FILE *fp;
 char cwd[PATH_MAX];
 /*  属性的当前工作目录崩溃的过程 */
 snprintf(cwd, PATH_MAX,  /proc/%s/cwd , argv[1]);
 chdir(cwd);
 /*  将输出写到该目录下的文件 core.info  */
 fp = fopen( core.info ,  w+ 
 if (fp == NULL)
 exit(EXIT_FAILURE);

 fprintf(fp,  argc=%d\n , argc);  for (j = 0; j   argc; j++)  fprintf(fp,  argc[%d]= %s \n , j, argv[j]);  /*  计算标准输入 (核心转储) 中的字节数 */  tot = 0;  while ((nread = read(STDIN_FILENO, buf, BUF_SIZE))   0)  tot += nread;  fprintf(fp,  Total bytes in core dump: %d\n , tot);  return 0; }

注意一下:  这里是指在进程当前工作目录的下创建。通常与程序在相同的路径下。但如果程序中调用了 chdir 函数,则有可能改变了当前工作目录。这时 core 文件创建在 chdir 指定的路径下。有好多程序崩溃了,我们却找不到 core 文件放在什么位置。和 chdir 函数就有关系。当然程序崩溃了不一定都产生  core 文件。

下面通过的命令可以更改 coredump 文件的存储位置,如下:

echo “|$PWD/core_pattern_pipe_test %p UID=%u GID=%g sig=%s”   
/proc/sys/kernel/core_pattern

cat /proc/sys/kernel/core_pattern 查看路径已经变为如下:

下面带大家配置永久的 core。只要出现内存访问越界、使用空指针、堆栈溢出等情况,都可以在这个目录下查看。

配置 core

1、首先在根目录下建立一个储存 coredump 文件的文件夹,命令如下:

mkdir /corefile

2、设置产生 coredump 文件的大小,命令如下:

ulimit -c unlimited

3、执行以下两条命令:

echo “1”   /proc/sys/kernel/core_uses_pid // 将 1 写入到该文件里
echo “/corefile/core-%e-%p-%t”   /proc/sys/kernel/core_pattern

将 coredump 产生的格式制定好写入 core_pattern 文件,这样当 coredump 产生时会直接以这种格式存入到根目录下的文件夹 corefile 中。

4、修改配置文件 /etc/profile

vim /etc/profile

添加 ulimit -S -c unlimited /dev/null 2 1

执行命令生效该文件

5、在配置文件 /etc/rc.local 中最后面添加信息(机器重启时会自动加载该命令):添加命令:

rm -rf /corefile/*

机器重启时清空该文件夹,由于产生的 coredump 文件很大,若不清空的话时间长了会将硬盘占满;

再执行以下两条命令:

echo “1”   /proc/sys/kernel/core_uses_pid
echo “/corefile/core-%e-%p-%t”   /proc/sys/kernel/core_pattern

测试
下面写个例子测试一下是否配置好了 corefile 文件

#include stdio.h int main(int argc, char *argv[]){int *p = NULL; *p = 3; return 0;}

编译运行,注意这里需要 - g 选项编译。

进入前面创建的 corefile 文件夹:

出现 core 文件表示完成 coredump 配置。可以用通过 readelf 命令进行判断是否是 core 文件:

运行 gdb 阅读 core 文件,命令为“gdb 程序 对应 coredump 文件”,这时就进入 gdb 的提示符“(gdb)”。

从红色方框截图可以看到,程序中止是因为信号 11。

下面可以通过 bt(backtrace)命令(或者 where)可以看到函数的调用栈情况:

即程序执行到 test.cpp 的第 6 行是出现段错误。原因是指向了空指针。

关于“linux core 指的是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注丸趣 TV 行业资讯频道,丸趣 TV 小编每天都会为大家更新不同的知识点。

向 AI 问一下细节

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2024-02-04发表,共计3201字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)