1. 问题
程序员经常会面临,开发电脑上一切运行正常,但是在测试电脑上却死活都有问题。一般情况下,我们可加一些弹窗或是打印Log来进行分析调试。但是如果问题复杂时,以上方法调试还是比较麻烦。如果可以像开发电脑一样,可以单步运行,并可以查看各种变量、堆栈信息,那就非常方法。有人直接在测试电脑上安装编译调试工具,但是有时问题是出现在客户电脑上,此时去安装相关编译调试工具,就非常不方便。那么有没有一种方法,不用安装Visual Studio,就能方便地直接对测试电脑进行调试呢?
另外,Windows内核程序的调试,有时是无法在测试电脑上进行的,因为内核程序运行时,Windows可能还没有启动完全。
2. 远程调试
针对以上问题,远程调试(也称双机调试)技术被开发出来。远程调试,即使用开发电脑通过网络、管道、串口、1394或USB等信息通信手段来与测试电脑进行连接,来控制测试电脑进行调试。两台电脑之间通信,更常用的方法是网络通信,即使用TCP/IP协议进行通信。
2.1. 准备
- 调试服务器,即需要调试的远程电脑。
- 调试客户端,即进行远程操作的电脑,也即开发电脑。
- 正常的TCP通信,保证两电脑在同一个局域网中,并且可以正常的ping连接,而且两台电脑应该处于同一个网段。如果调试服务器处在子路由网络,开发电脑处在父路由网络,可能无法进行连接。
2.2. 远程监控
实时查看Log信息时,需要使用一些监控工具。DbgView是Windows出品的调试信息监控查看工具。DbgView不仅可以在测试电脑上直接运行查看相关调试信息,还可以在开发电脑上运行查看测试电脑上程序运行的调试信息。
其基本原理是,在测试电脑上运行DbgView,对程序运行进行监控,然后在开发电脑上打开DbgView,然后连接测试电脑上的DbgView。这样开发电脑就可以实时显示测试电脑上的调试信息。
- 测试电脑上,通过命令启动DbgView
DbgView /a /k /g
- /a表示以服务器方式启动DbgView。
- /表示监控内核输出。
- /g表示监控全局Win32l输出。
- 在开发电脑上,直接打开Dbgivew
选择菜单Computer->Connect,输入测试电脑IP或计算机名,点击确定。
连接成功,即会显示下图。DbgView可以同时监控本机和远程电脑,可以选择Disconnect本地连接,只监控远程电脑。
- DbgView的版本最好保持一致,避免可能连接不成功。测试使用的Verson 4.81。
2.3. VS远程调试
- 将VS目录中的Remote Debugger目录整个拷贝到远程电脑上去。
- 根据远程电脑情况,选择相应内核版本目录打开msvsmon.exe
- 首次打开msvsmon.exe需要配置防火墙信息
- 选择菜单Tools->Options进行如下配置,并记录Server Name用于远程连接。
- 将exe/dll及对应的pdb文件拷贝到远程电脑上,并启动exe
- 打开开发电脑VS代码工程,选择Attach to Process,并在Qualifier中填入远程电脑名,并回车确认,然后Available Process中选择远程电脑上需要被调试的进程,并点击Attach,即可以进行调试。
2.4. WinDbg远程调试
WinDbg的调试功能比VS更加强大,不仅仅可以调试应用程序代码,还可以调试内核代码。WinDbg远程调试,即远程电脑上启用WinDbg进行具体执行,而开发电脑上的WinDbg则通过网络连接远程电脑上的WinDbg进行操作和显示。
- 将需要调试的exe/dll及PDB文件拷贝到远程测试电脑上。
- 远程电脑上打开WinDbg,并打开需要调试的exe,WinDbg会立即中断在exe的入口函数处。
- 在WinDbg命令框中输入 .server tcp:port=5000 并按回车,显示如下
也可以通过命令行WinDbg -server tcp:port=5000直接启动WinDbg服务器模式。
- 在打开电脑上打开WinDbg,连接服务端WinDbg。
选择菜单File->Connect to remote Session,填入相应的IP及端口
tcp:Port=5000,Server=172.18.41.31
也可以直接通过命令行WinDbg -remote tcp:Port=5000,Server=172.18.41.31进行启动并连接服务端WinDbg,
- 设置符号文件
在命令框中输入 .sympath srvD:\MyServerSymbolshttps://msdl.microsoft.com/download/symbols - 重新加载符号文件
在命令框中输入 .reload,并回车,即会重新下载并加载系统符号文件 - 指定源代码路径
- 设置断点
- 按F5,运行程序到断点处,即可以单步调试
3. 其他
- exe/dll、pdb文件和源代码一定要保持编译时的版本。
- 远程电脑和本地电脑上的调试工具版本要对应。
- 更多WinDbg调试信息见WinDbg调试。