加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 将大型核心文件转换为“minicore”文件

发布时间:2020-12-16 07:32:38 所属栏目:百科 来源:网络整理
导读:如何将核心文件减少到线程的堆栈? 我希望能够在迷你核心上运行gdb thread apply all bt而不再需要 我正在处理大型( 4GB)多线程Linux ELF核心文件,这些文件太大而无法回来进行分析. 我看到google-breakpad是为了在进程崩溃时创建一个“minidump”.在google-b
如何将核心文件减少到线程的堆栈?

我希望能够在迷你核心上运行gdb thread apply all bt而不再需要

我正在处理大型(> 4GB)多线程Linux ELF核心文件,这些文件太大而无法回来进行分析.

我看到google-breakpad是为了在进程崩溃时创建一个“minidump”.在google-breakpad中有两个实用程序core2md和minidump-2-core,它们乍一看应该能够将核心文件转换为minidump格式,然后通过堆栈信息从minidump返回核心文件.这个问题是core2md需要来自/ proc / $PID /下的进程信息,这不是我所拥有的.

解决方法

可能你最好的选择是将google breakpad集成到你的Linux进程中,这样当崩溃发生时,google breakpad会记录崩溃,而不是创建核心文件的操作系统.这将为您提供所需的信息,然后您可以使用minidump_stackwalk转储调用堆栈(方便汇总大量崩溃),也可以使用minidump-2-core创建核心文件.

不幸的是,Linux似乎没有一种有效的方法来创建只有线程堆栈内容的最小核心文件.这些文件(Windows世界中的小型转储)非常有用 – 它们具有非常高的信息大小比例,可以轻松收集数百万个故障转储.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读