本文主要是介绍LINUX系统编程:核心转储,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目录
核心转储
这两个有什么区别呢?
那为什么在我们使用Core终止进程时没看见core文件呢?
那为什么这么好用的功能是被关闭的呢?
如何开启核心转储
写个除零错误验证一下
使用Core文件
核心转储
在使用信号的时候,我们发现大多数的信号都是终止进程,虽然都是终止进程,但是终止进程是有两种方式的。一个是core一个是term。
这两个有什么区别呢?
Term终止就是正常的终止,操作系统将进程pcb,页表等等内核数据结构直接干掉。
Core终止,在终止之后会生成,一个core文件,将进程在内存中的内核数据(与调试有关)转储到磁盘当中形成core文件,然后将进程干掉。
这个core文件主要就是可以协助程序员进行调试。
那为什么在我们使用Core终止进程时没看见core文件呢?
因为这个功能在云服务器是默认关闭的。
那为什么这么好用的功能是被关闭的呢?
当一个服务挂了,第一肯定是先恢复服务,然后在去解决问题。
一些服务挂掉了,会由程序自动重启。
如果每次启动就挂掉,会一直重启,一直挂掉,会生成很多的core文件,最后磁盘被打满,整个系统就挂了。
如何开启核心转储
ulimit -a //查看用户对系统资源的访问
我们发现core文件默认的最大大小是0,我们只需要将core文件最大大小修改一下,确保能够捕获足够的信息用于调试即可。
ulimit -c 10240//将core文件最大大小设置为10240
在使用ulimit -a 查看一下
将Core文件的生成路径设置为当前路径
sudo bash -c "echo %E.core.%p.%t > /proc/sys/kernel/core_pattern"
写个除零错误验证一下
除零错误会收到SIGFPE,终止方式为Core
demoCode
#include<iostream>
int main()
{int a = 10;int c = a/0;return 0;
}
未开启
开启之后
生成的文件
使用Core文件
gdb testCoreDump
直接调试可执行程序
core-file 生成的core文件
这篇关于LINUX系统编程:核心转储的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!