部署环境:ASP.NET(C#)+IIS+Win7 64 bit
很多公司的开发模式都是将开发机器和服务器分开,也就是开发一台机,服务器一台机。而测试人员会在服务器上录入测试数据,此时报错了【由于开发程序时忽略了数据类型或者数据是否合法导致的】,如果是简单的错误那还好办,看下代码直接消灭。要是生命力比较顽强的bug,那么就需要调试了。
此时开发人员会产生几种设想:
1、赶紧把服务器的环境部署到本地,然后把生成的dll扔进去进行调试。这时会出现几种结果,如果顺利的话,通过了调试解决了bug,如果不顺利的话,就会延长bug的解决时间。不顺利的情况可能会有:对程序的配置不熟悉,本地可能在注册表缺少了对那个插件的注册,目录可能存在中文……种种的,种种的问题。
2、在服务器上装上一个Visual Studio 2008/2010/2012[后面简称vs工具],然后把程序文件拷过去,然后将生成的文件dll附加到iis进程而进行调试,哈哈,顺利解决了bug,但是一看钟表半天过去了。而且服务器多了很多文件,仅仅是为了你调试这个程序的文件。如果是管理不是很严谨的公司那还说的过去,要不然少不了要被喷一顿。
好吧,不说口水话了,进入正题。
第一步:将vs工具里的Remote Debugger文件夹拷贝到目标机器。大致的目录应该是:D:Program Files (x86)Microsoft Visual Studio 10.0Common7IDERemote Debugger,或者从开始菜单那里可以找到它的快捷方式,如下图:
第二步:在服务器上打开Remote Debugger文件夹,如果是32位的就运行X86里面的msvsmon.exe,如果是64位的就运行X64里面的msvsmon.exe。关于32位和64位这里要注意一下,以你的IIS应用程序池为主,在应用程序池那里右键,点击高级设置,可出现以下窗体。如果启用32位应用程序设置为true的话,那么就需要运行X86里面的msvsmon.exe。
运行后会出现以下界面
第三步【最关键一步】:将你本地的账号密码设置成跟服务器一样,因为远程调试也是需要用户凭证的。账号和密码都要一致哦!!!
第四步:用vs工具打开你的程序源码,用快捷键ctrl + alt + p 打开附加进程窗体,如下图
传输:默认
限定符:默认是本机的机器名称,设置为你的服务器IP(如:192.168.1.250)
设置好按回车就可以看到250这台机子的进程,然后找到w3wp.exe这个进程,点击附加。【如果没有看到w3wp.exe,可以把下面显示所有用户的进程勾上】
接下来就尽情享受代码的调试把。
需要远程调试,但是启动服务器vs2012的Remote Debuggerx64msvsmon.exe时,提示未安装Windows Web Server API,百度谷歌了半天,发现关于安装这个api的问题似乎很少,最终在谷歌里翻到了一篇解决办法:
(1) 下载Windows Live Essentials Offline installer (http://g.live.com/1rewlive5-all/en/wlsetup-all.exe),使用迅雷下载最好,速度比较快。
(2) 使用解压工具解压下载的exe,我是用的是UniExtract。
(3) 接下来就用这个软件把下载的exe解压出来,注意要设置解压模式的话用第三个选项。解压出一个文件夹,在文件夹的根目录取出文件“PACKAGEP46104728"和”PACKAGEP31914638“,用UniExract对他俩分别解压,得到压缩文件,一直解压到剩余两个文件”Windows6.0-KB959175-x86.msu“,”Windows6.0-KB959175-x64.msu“,根据服务器是32位或64位使用对应的x86或x64程序,放置在服务器上更新Windows Web Server API,这样就解决了这个问题。