码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Dump文件分析 - PDB强制匹配流程


    适用场景

    软件开发中,经常会有PDB符号文件丢失,源码无法复原到原版本,软件运行中崩溃。导致我们软件生成的Dump信息无法匹配到PDB,这样有vs打开及windbg打开无法查看到软件崩溃的位置,这样就会浪费很多我们的排查时间。下面这种方式就是用Windbg去强制匹配PDB文件(近几个版本的)

    前置条件

    1.需要分析的Dump文件
    2.与其不匹配的PDB文件(最好是近几个版本的)

    指令

    1.查看堆栈:k
    2.解析dump:!analyze -v
    3.重新加载模块符号:.reload /f xxx.dll
    (单独的.reload /f 加载所有依赖模块符号)
    4.强制加载模块符号:.reload /i xxx.dll
    (/i 指令强制加载主要使用指令)

    实际步骤

    1.打开windbg先加载符号路径,设置我们的PDB路径(重要)
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-M1jlmPQt-1669812948762)(http://10.1.65.34/group1/M00/22/61/CgFBImOHSfmAdI8pAACea0N_kFc676.png)]

    2.打开Dump文件
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Ab11flFD-1669812948768)(http://10.1.65.34/group1/M00/22/61/CgFBImOHSaiAJL0qAAD1zPE90Yo525.png)]

    3.打开的Dump如下图
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Orb52rMy-1669812948769)(http://10.1.65.34/group1/M00/22/62/CgFBImOHS6CADhdkAABgmDe6Vk8955.png)]

    4.输入!analyze -v指令,查看Dump信息
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-iDWSgeNK-1669812948775)(http://10.1.65.34/group1/M00/22/66/CgFBImOHUNCAIHDhAAEjPCN27UQ735.png)]

    5.接着输入.reload /f 重新加载所有符号表,查看那些没有被加载,首先我所需要的PDB是下图红色的框内
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-sYZPowDF-1669812948776)(http://10.1.65.34/group1/M00/22/66/CgFBImOHUlGAMwlQAAGFN-M9d_Q489.png)]

    6.接着输入 .reload /i MH EGWS Hysteroscop.exe 无报错即成功
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-OEsNmILO-1669812948782)(http://10.1.65.34/group1/M00/22/66/CgFBImOHUeGAEtMDAAAJzpvct8k122.png)]

    7.再次输入!analyze -v指令,查看Dump信息

    8.输入k可查看堆栈调用顺序

  • 相关阅读:
    uniapp项目打包H5后 希望可以修改固定的配置(接口地址,系统名称等)
    CPS305 Lab 5
    element中el-switch用法汇总(拓展:el-switch开关点击弹出确认框时,状态先改变,点击确认/取消失效,怎么解决?)
    RCE(Pikachu)
    部署zabbix服务
    让古迹“活”起来!荣耀的软人文和硬科技
    负载均衡四层和七层的区别
    C++读写Excel有许多开源库
    学习尚硅谷HTML+CSS总结
    实战SpringMVC之CRUD
  • 原文地址:https://blog.csdn.net/amxld/article/details/128122260
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号