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

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

 

转载于:https://www.cnblogs.com/rock_chen/archive/2012/07/12/2587516.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值