记一个在live debugging一个托管进程时, BPMD无法定下断点的问题的解决方案
SharePoint 2010的某些DLL会被进行一种叫做Pre-compiling的优化, 所使用的工具叫做Ngen.exe. 优化过后, 托管的dll会被制作为native image, 之后呢Runtime每次都会使用native image, 而不是传统的托管DLL. 这种优化可以加快DLL的加载, 因为需要执行代码的很多动作都被提前做好了.
然而, 这样的优化会给在WinDBG中Live Debugging这样的任务制造困难. 由于使用的是native image, 像BPMD这样的命令就无法定义断点了.
解决方案
================
修改注册表键值, 关掉这种优化.
1) 打开如下的注册表键值: HKLM\Software\Microsoft\.NET Framework\
2) 添加一个 DWORD 值, 名字叫做"ZapDisable”, 然后赋值为 1
3) 重启目标进程
关于Native Image的更多信息
===============
Native Image Generator (Ngen.exe)
http://msdn.microsoft.com/en-us/library/6t9t5wcf%28VS.71%29.aspx