当前位置: 首页 > 面试题库 >

最小的核心转储(仅堆栈跟踪+当前帧)

权玉泽
2023-03-14
问题内容

我可以在Linux上配置进入核心转储的内容吗?我想获得类似Windows小型转储(当应用崩溃时有关堆栈帧的最少信息)。我知道您可以使用设置核心文件的最大大小ulimit,但这不能让我控制核心文件的内容(即无法保证如果将限制设置为64kb,它将转储文件的最后16页)例如堆栈)。

另外,如果可能的话,我想以编程方式(从代码)进行设置。我已经看过/proc/PID/coredump_filter提到的文件man core,但是对于我来说,它看起来太粗糙了。

提供一些背景信息:出于多种原因,我需要很小的核心文件:我需要通过网络为大量(数千个)客户端收集它们;此外,它们是带有少量SD卡的嵌入式设备,以及用于网络连接的GPRS调制解调器。因此,任何超过200k的问题都不容置疑。

编辑:我正在运行linux 2.6.24的嵌入式设备上。处理器是PowerPC。不幸的是,当前在breakpad中 支持powerpc-linux
,因此无法使用google breakpad


问题答案:

我已经通过两种方式“解决”了这个问题:

  1. 我为SIGSEGV安装了一个信号处理程序,并使用backtrace / backtrace_symbols打印出堆栈跟踪。我用-rdynamic编译了我的代码,因此即使剥离了调试信息,我仍然得到带有有意义名称的回溯(同时保持可执行文件足够紧凑)。
    我剥离了调试信息,并将其放在一个单独的文件中,我将使用将该文件存储在安全的地方strip。从那里,我将使用add22line从回溯(地址)中保存的信息来了解问题发生的位置。这样,我只需要存储几个字节。

  2. 另外,我发现我可以使用/ proc / self / coredump_filter不转储任何内存(将其内容设置为“0”):仅线程和proc信息,寄存器,stacktrace等保存在内核中。

我仍然丢失了可能有价值的信息(全局和局部变量内容,params ..)。我可以很容易地找出要转储的页面,但是不幸的是,无法为正常的核心转储指定“ dump-
these-pages”(除非您愿意maydump()在内核中对该功能进行修补)。

现在,我对2种解决方案感到非常满意(总比没有好。.)我的下一步是:

  • 看看将Breakpad移植到powerpc-linux会有多困难:已经有powerpc-darwin和i386-linux了..这有多难?:)
  • 尝试使用google-coredumper在当前ESP(应该给我本地和参数)和“&some_global”(应该给我全局变量)周围仅转储几页。


 类似资料:
  • 当Xdebug被激活时,只要PHP决定显示通知,警告,错误等,就会显示堆栈跟踪。堆栈跟踪显示的信息以及显示方式可以根据您的需要进行配置。 Xdebug在错误情况下显示的堆栈跟踪信息量相当保守(如果display.errors 在php.ini中设置为On)。这是因为大量的信息会减慢脚本的执行速度和浏览器中堆栈跟踪本身的渲染速度。但是,可以使堆栈轨迹以不同的设置显示更详细的信息。 堆栈跟踪中的变量

  • 问题内容: 我正在尝试转储所有活动线程的列表,包括每个线程的当前堆栈。我可以使用threading.enumerate()获得所有线程的列表,但是我不知道从那里到堆栈的方法。 背景:Zope / Plone应用程序有时会出现故障,消耗100%的cpu,需要重新启动。我觉得这是一个循环,无法正常终止,但是我无法在test- environemt中重现该循环以进行验证。我设法注册了可以从外部触发的信号

  • 问题内容: 如何获得Java中的当前堆栈跟踪,就像你可以在.NET中那样? 我找到了,但这不是我想要的-我想找回堆栈跟踪信息,而不是打印出来。 问题答案: 你可以使用。 这将返回一个数组,该数组代表程序的当前堆栈跟踪。

  • 问题内容: 有没有一种方法可以Throwable.printStackTrace(PrintStream s)打印出完整的堆栈轨迹,以便我能看到的最后一行”… 40 more”? 问题答案: 你不需要 该信息存在于堆栈跟踪中的其他位置。来自的文档printStackTrace(): 注意存在包含字符的行。这些行指示此异常的堆栈跟踪的其余部分与由该异常(“封闭”异常)引起的异常的堆栈跟踪的底部指示的

  • 我使用以下代码打印try-catch块中发生的任何异常,但是当异常发生时,logback不会打印完整的堆栈跟踪,而是写入一行错误(它没有明确说明是什么导致了它。我如何在logback输出中打印完整的堆栈跟踪? 尝试捕获异常的catch块 日志返回错误输出:

  • 问题内容: 如何将异常的堆栈跟踪信息打印到stderr以外的流上?我发现的一种方法是使用getStackTrace()并将整个列表打印到流中。 问题答案: 可以接受or或参数: 也就是说,请考虑将SLF4J之类的记录器接口与LOGBack或log4j之类的记录实现一起使用。