C++ 生成的dump文件,在别的机器用VS打开dump看不到堆栈的原因

本文讲述了在调试Windows服务器2008环境下生成的dump文件时遇到的无法查看堆栈信息的问题。问题根源在于VS2005之后版本的异常处理机制,需要设置异常处理函数。调试dump文件时,需要匹配的exe、dll、pdb文件及VC运行库版本。解决方案包括安装相应版本的VC运行库或复制生产环境的msvcr90.dll到dump文件目录。确保所有组件版本一致才能正确调试。
摘要由CSDN通过智能技术生成

        我们公司开发的证券交易系统启用了生成dump文件的机制,在生产环境的机器上发生了崩溃,生成了一个dump文件,当拿到我们开发的机器上调试,却看不到堆栈信息。一开始简单的以为,是exe、dll、pdb等不匹配导致的问题,接着又怀疑是生产环境的Windows server 2008系统生成的dump问题,后来以为是生成dump的代码不够规范,但经过各种尝试都是没有效果。于是,在未来的一两个星期里,我花了大量时间去找其中的原因,终于皇心不负有心人,我找到问题的原因并解决。

       VS2005之后的版本,微软增加了一些新的异常机制,新机制在出现错误时默认不通知应用程序,这时程序就崩溃了。所以这种情况下,必须调用_set_invalid_parameter_handler、_set_purecall_handler、_set_se_translator等设置自己的异常处理函数。这几个函数用法,可以自行百度,这里不细说。

而正是新机制生成的dump文件,导致我们可能在别的机器看不到调试信息。

调试时,系统会查找exe或者dll中指定位置的pdb文件,并且会跟踪exe或者dll中pdb的校验码GUID来对现有的pdb文件进行版本校验。新机制生成的dump文件,不仅需要同版本的exe、dll、pdb文件,还需要运行库的匹配。

当我们把dump文件拿到别的机子去调试,如果看不到堆栈信息,应该会在输出窗口看到类似这种信息:

      

框起来的部分就是需要的VC运行库的版本号。本机VC运行库的版本号可以在已安装程序里面看到:

这个版本号如果和你本机安装的VC运行库的版本号不是完全一致的话,就会提示“找不到匹配的二进制”,需要安装同样版本号的VC运行库,或者到生产环境的同名目录下找到这两个dll,放到和dump文件同一个目录下。之所以放在当前目录下可行,是因为它会先在当前目录找到匹配版本的msvcr90.dll,找不到再去绝对路径找。

两个运行库的dll放到dump文件目录下后,再次启动调试就可以正常看到堆栈信息了,大功告成。

关于调试dump需要提供的文件,我补充说明下,总的来说要提供3类文件:

1、匹配VC++运行库版本号的dllMSVCXX.dll,可以通过输出窗口找到对应的路径,到崩溃机的同样路径下找)或者本机装用匹配版本号的运行库、

2、生成dump代码的模块(exedll),

3、发生崩溃的模块(exedll)和它的pdb文件

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
C/C++应用程序在遇到宕机或崩溃时,可以生成dump文件,用于分析和排查问题。dump文件是一个二进制文件,包含了应用程序当前状态的所有信息,例如寄存器的值、堆栈信息、内存快照等。 生成dump文件的过程通常需要在宕机发生时进行设置,在代码中添加相应的处理逻辑。可以使用操作系统提供的工具或使用一些第三方库来生成dump文件。 在Windows操作系统中,可以使用Windows Error Reporting(WER)来生成dump文件。WER会通过注册表设置或程序运行时设置来配置生成dump文件的方式和路径。可以通过指定参数和设置注册表来控制生成dump文件的级别(如只生成小型或完全的dump文件)。当应用程序发生崩溃时,WER会拦截并触发生成dump文件。使用WER生成dump文件可以在调试器中打开进行分析。 在Linux操作系统中,可以使用glibc库的backtrace机制来生成dump文件。通过设置信号处理函数,将崩溃时的堆栈信息写入文件。可以通过注册信号处理函数,并在函数中使用backtrace和backtrace_symbols将堆栈信息写入文件。 除了使用操作系统提供的工具和机制,还可以使用一些第三方库来生成dump文件,如Google Crashpad和Breakpad等。这些库提供了更灵活和可定制的选项,可以在崩溃发生时执行回调函数,并根据需求生成dump文件。 总之,通过生成dump文件,我们可以在程序崩溃时获取并保存关键的调试信息,有助于分析和定位问题的根源,提高应用程序的稳定性和可靠性。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值