windbg远程调试方法

来源:互联网 发布:数据确权 编辑:程序博客网 时间:2024/05/23 21:50
windbg远程调试方法  


From: http://blog.csdn.net/ytfrdfiw/article/details/8865527
WinDBG
的远程调试由服务端和客户端组成,和
visualstudio类似。被调试的机器是服务端(server),我们做调试的机器是客户端(client)两台机器都需要安装WinDBG
第一步,建立WinDBG server端。
使用 -server参数可以使WinDBG以服务器方式启动。 WinDBG可以用多种连接协议让客户端连接,比如命名管道(named pipe),安全管道(secure pipe), TCP协议(socket), SSL协议,串口/并口(COM port)等等。
第二步,WinDBG client端连接服务端
  
使用 -remote参数可以使WinDBG以客户端方式启动去连接服务端,可以指定不同的连接方式:比如命名管道(named pipe),安全管道(secure pipe), TCP协议(socket), SSL协议,串口/并口(COM port)等等。
我这里以tcp协议为例,用管道或其他我暂时没有试验成功。
PC1
:被调试主机

PC2:
调试机客户端
PC1
执行的步骤如下:
1
)、运行cmd.exe
2)
、进入windbg的安装目录
3
)、运行以下命令
(1)
windbg–server tcp:port=5005 c:\aa.exe  
一般会出现下图所示界面:

注意红色部分,如果此时,你输入g命令,则aa.exe程序正常运行,你将不能调试程序的初始化流程如(dllmainmain,此时如果用客户端调试PC1,则相当于我们平时的attatchprocess的动作。反之,此时,你不做任何事情,直接到PC2上,执行调试流程,则可以调试PC1上的aa.exe初始化流程,此时相当于我们在vsF5调试。
2)、windbg–server tcp:port=5005  –p 1002       
这也是一种调试方法,其中,-p 1002中的1002是我们想调试的进程ID,这种调试模式相当于attatch toprocess的模式,不能调试dllmainmain函数.
PC2
执行的步骤如下:
1
)、运行cmd.exe
2)
、进入windbg的安装目录
3
)、运行以下命令
windbg –remote tcp:port=5005,server=192.168.33.11
另外,要注意,pdb文件一定放置在PC1上面,在PC2windbg里设置的符号文件路径也一定设置PC1的路径,否则在PC2的调试器中会出现无法打开路径的警告

0 0
原创粉丝点击