IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> Linux 下 Segmentation fault (core dumped)调试-core文件 -> 正文阅读

[系统运维]Linux 下 Segmentation fault (core dumped)调试-core文件

最近遇到一个app异常退出的bug,App log中有做好的 gdb_crash log (gdb_crash_pbshell_2022-03-0312_36_54),可以显示函数调用栈和错误信息

Core was generated by `./pbshell mfg’.
Program terminated with signal SIGSEGV, Segmentation fault.

说明app异常退出时发生了段错误,访问空指针导致的(系统受到SIGSEGV信号时,杀死当前进程)。网上搜了“Program terminated with signal SIGSEGV, Segmentation fault.”,发现Linux下程序发生段错误会自动生成core文件。(当前的gdb_crash_pbshell_2022-03-0312_36_54.txt 应该就是core文件)。
以前不知道程序crash还会有core文件产生, 于是就想研究一下core文件是怎么产生的,里面都有什么内容,已经如何使用它。

1. 默认情况下,core文件会在当前可执行程序所在路径产生。

例如:
写一个会产生段错误的demo (路径: ~/workspace/demo):

include<iostream>
  
int main()
{
        int * p=NULL;
        *p=1;
        return 1;
}

编译: g++ -g test.cpp
执行: ./a.out
报错: Segmentation fault(core dumped).
查看当前目录,发现多了一个core文件。
在这里插入图片描述

2.拿到core文件后怎么查看调用栈:

执行:gdb a.out core
在这里插入图片描述

3. 问题

crash时候,不产生core文件。
解决:
首先考虑系统限制问题
shell键入 ulimit -a
查看core文件有没有限制大小,发现没有,是unlimited,所以不是这个原因
(如果大小为0,说明禁止了core文件的产生,可以通过 ulimit -c unlimited 来解除限制)

其次考虑是不是程序实现和权限方面的问题
查阅资料,总结不产生core的相关情况如下:

程序设置了用户id(即调用setuid),但当前用户并非该程序文件的所有者
程序设置了组id(即调用setgid),但当前用户并非该程序文件的组所有者
用户没有当前目录或指定core文件产生目录的写权限
core文件太大,磁盘空间不足
但以上并没有解决我的问题

其次考虑core文件产生位置
core的缺省位置是程序所在目录,可以通过修改**/proc/sys/kernel/core_pattern**来指定core文件生成位置。
通过查看core_pattern文件,发现其确实指定了一个路径,
在这里插入图片描述
于是我前往那个路径,发现竟然是可执行程序,后来查看说明文件,才知道core_pattern中如果首先指定了一个 ‘|’ 管道符,则会将生成的core文件传递给后面所跟的脚本去处理。
至此,也就确定了问题的原因,| 管道符后面的脚本将我们的core文件给吞了,解决方法自然就是去掉这个脚本,换成自己指定的目录
但直接去修改core_pattern文件并没有成功,保存时会提示FSync错误,查阅资料得知,这个文件有特殊限制,只能通过命令:
sudo bash -c "echo 这里是写入内容 > /proc/sys/kernel/core_pattern "
我使用:
sudo bash -c “echo core > /proc/sys/kernel/core_pattern "
来进行写入,即指定程序所在目录为core文件生成目录,core文件名称为"core”。

之后再运行程序,core dump后,即在当前程序文件目录下生成了core文件

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-04-07 23:07:00  更:2022-04-07 23:09:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 5:24:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码