现在的位置: 首页 > 综合 > 正文

用WINBDG 查看 IIS7.5 CPU 100% 原因

2011年01月17日 ⁄ 综合 ⁄ 共 439字 ⁄ 字号 评论关闭

服务器: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 解决了

 

抱歉!评论已关闭.