服务器:CPU 4 核,WIN2008 R2 64位
.NET MVC 的程序在压力测试(20个用户无思考时间)下,CPU 总是莫名的100%,数据库 CPU 为0,w3wp.exe *32的CPU为100%
判断:程序出现的死循环,由于在压力下才出现,所以可以断定 多线程访问对象是出的问题。
在任务管理器中看到的线程为:w3wp.exe *32(通过应用程序池-“启用32位应用程序”可以设置32位还是64位)
*32 说明要用 32 位的 Windbg 来分析.
用 Windbg 加载进程 w3wp.exe *32
输入命令:
.load C:\Windows\Microsoft.NET\Framework\v4.0.30319\sos.dll
.loadby sos clr
!runaway (查看 CPU 运行时间)
~* e !clrstack (列出所有线程的调用堆栈)
到此可以很清楚看到问题
对 static Dictionary<Type, string> 的访问引发了死循环是程序出来问题的地方
用 lock 解决了