博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
windbg java.pdb,PDB符号文件与Windows下利用Windbg 分析dump
阅读量:6157 次
发布时间:2019-06-21

本文共 3183 字,大约阅读时间需要 10 分钟。

PDB简介

跟踪提供程序(例如应用程序或驱动程序)的程序数据库

(PDB) 符号文件包含用于对跟踪消息设置格式的指令,以便可以按照用户可读的形式显示这些消息。

跟踪消息格式设置指令属于跟踪提供程序源代码的一部分。 WPP

预处理器从代码中提取这些指令并将其添加到跟踪提供程序的 PDB 符号文件。

当你编译调试(已检验)版本的跟踪提供程序时,编译器生成 PDB 文件。默认情况下,当你使用 BinPlace 生成跟踪提供程序时,生成过程将创建

PDB 文件。

WDK 中的 跟踪使用器、 TraceView 和 Tracefmt 可以从

PDB 文件或 TMF 文件中直接提取跟踪消息格式设置信息。其他的则要求 TMF 文件。 Tracepdb 将

PDB 文件作为输入,提取格式设置信息,然后创建 TMF 文件作为输出。

其他跟踪使用器不使用 PDB 文件或 TMF 文件,例如包含在 Windows 中的工具 Tracerpt。相反,它们使用托管对象格式 (MOF) 文件中的信息为跟踪事件设置格式。这些工具无法对跟踪消息设置格式。

概述:

注册生成dump文件的函数。

当程序收到没有捕获的异常时,调用上述函数,生成dump文件。

利用Windbg结合编译程序时生成的pdb和代码来分析dump文件,定位问题。

如下代码生成dump文件(转):

84216097_1.gif

#include #include#include

#pragma comment(lib, "dbghelp.lib") inline BOOL IsDataSectionNeeded(const WCHAR*pModuleName)

{if(pModuleName ==NULL)

{returnFALSE;

}

WCHAR szFileName[_MAX_FNAME]= L"";

_wsplitpath(pModuleName, NULL, NULL, szFileName, NULL);if(wcsicmp(szFileName, L"ntdll") == 0)returnTRUE;returnFALSE;

}

inline BOOL CALLBACK MiniDumpCallback(PVOID pParam,constPMINIDUMP_CALLBACK_INPUT pInput,

PMINIDUMP_CALLBACK_OUTPUT pOutput)

{if(pInput == 0 || pOutput == 0)returnFALSE;switch(pInput->CallbackType)

{caseModuleCallback:if(pOutput->ModuleWriteFlags &ModuleWriteDataSeg)if(!IsDataSectionNeeded(pInput->Module.FullPath))

pOutput->ModuleWriteFlags &= (~ModuleWriteDataSeg);caseIncludeModuleCallback:caseIncludeThreadCallback:caseThreadCallback:caseThreadExCallback:returnTRUE;default:;

}returnFALSE;

}

inlinevoidCreateMiniDump(PEXCEPTION_POINTERS pep, LPCTSTR strFileName)

{

HANDLE hFile= CreateFile(strFileName, GENERIC_READ |GENERIC_WRITE,

FILE_SHARE_WRITE, NULL, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);if(hFile !=INVALID_HANDLE_VALUE)

{

MINIDUMP_EXCEPTION_INFORMATION mdei;

mdei.ThreadId=GetCurrentThreadId();

mdei.ExceptionPointers=pep;

mdei.ClientPointers=FALSE;

MINIDUMP_CALLBACK_INFORMATION mci;

mci.CallbackRoutine=(MINIDUMP_CALLBACK_ROUTINE)MiniDumpCallback;

mci.CallbackParam=NULL;

::MiniDumpWriteDump(::GetCurrentProcess(), ::GetCurrentProcessId(), hFile, MiniDumpNormal, (pep!= NULL) ? &mdei : NULL, NULL, &mci);

CloseHandle(hFile);

}

}

LONG __stdcall MyUnhandledExceptionFilter(PEXCEPTION_POINTERS pExceptionInfo)

{

CreateMiniDump(pExceptionInfo,"core.dmp");returnEXCEPTION_EXECUTE_HANDLER;

}

84216097_1.gif

确保程序开始执行如下代码,然后程序崩溃时会调用上面代码创建dump文件:

SetUnhandledExceptionFilter(MyUnhandledExceptionFilter);

分析生成的dump文件需要如下:

编译程序时生成的PDB,如果是release版本:

需要禁用优化 - VS - Project Property - C/C++ Optimization - Release - Optimization - Disabled

启用生成调试信息 - VS - Project Property - Linker - Debugging - Generate Debug Info - Yes.

代码

分析dump文件步骤如下:

运行Windbg。

指定PDB文件路径: File - Symbol File Path。多个路径用分号分隔。

指定代码路径:File - Source File Path

载入dump文件。

Windbg命令行输入:  !analyze -v

等待结果 - 函数调用堆栈,程序崩溃代码。busy状态表示正在生成结果。

注释:

没有代码,只有PDB,也可以显示函数调用堆栈,但是不会定位到具体代码。

Windbg中,配置 Symbol File Path: srv*c:\symbols*http://msdl.microsoft.com/download/symbols,可以解决本地找不到symbol问题。定位一般问题,不是必须。c:\symbols为本地缓存PDB目录。只会同步用到的symbol。

Windbg的附带工具symchk可以用来下载指定dll的pdb文件:

下载特定dll的pdb文件:symchk /r c:\windows\system32\secur32.dll /s SRV*c:\symbols\*http://msdl.microsoft.com/download/symbols

下载特定目录下的dll的pdb文件:symchk /r c:\windows\system32 /s SRV*c:\symbols\*http://msdl.microsoft.com/download/symbols

如果dump文件被拷贝到编译程序的机器上,无需指定代码路径,只需指定pdb文件,可自动定位代码。

转载地址:http://kkifa.baihongyu.com/

你可能感兴趣的文章
活在当下
查看>>
每天进步一点----- MediaPlayer
查看>>
PowerDesigner中CDM和PDM如何定义外键关系
查看>>
跨域-学习笔记
查看>>
the assignment of reading paper
查看>>
android apk 逆向中常用工具一览
查看>>
MyEclipse 报错 Errors running builder 'JavaScript Validator' on project......
查看>>
Skip List——跳表,一个高效的索引技术
查看>>
Yii2单元测试初探
查看>>
五、字典
查看>>
前端js之JavaScript
查看>>
Log4J日志配置详解
查看>>
实验7 BindService模拟通信
查看>>
scanf
查看>>
Socket编程注意接收缓冲区大小
查看>>
SpringMVC初写(五)拦截器
查看>>
检测oracle数据库坏块的方法
查看>>
SQL server 安装教程
查看>>
Linux下ftp和ssh详解
查看>>
跨站脚本功攻击,xss,一个简单的例子让你知道什么是xss攻击
查看>>