1.!runaway

!runaway命令显示每个线程消费的时间

Bit 0 (0x1) 让调试器显示每个线程消耗的用户模式时间(user time),默认不加就是0x1
Bit 1 (0x2) 显示每个线程消耗的内核时间(kernel time)。
Bit 2 (0x4) 显示每个线程从创建开始经历了多少时间。
就是三者的组合:1 2 3 4 5 6 7
  1. 0:002> !runaway
  2. User Mode Time
  3. Thread       Time
  4. 0:890       0 days 0:00:00.031
  5. 2:a00       0 days 0:00:00.000
  6. 1:1174      0 days 0:00:00.000
  7. 0:002> !runaway 1
  8. User Mode Time
  9. Thread       Time
  10. 0:890       0 days 0:00:00.031
  11. 2:a00       0 days 0:00:00.000
  12. 1:1174      0 days 0:00:00.000
  13. 0:002> !runaway 2
  14. Kernel Mode Time
  15. Thread       Time
  16. 0:890       0 days 0:00:00.062
  17. 2:a00       0 days 0:00:00.000
  18. 1:1174      0 days 0:00:00.000
  19. 0:002> !runaway 3
  20. User Mode Time
  21. Thread       Time
  22. 0:890       0 days 0:00:00.031
  23. 2:a00       0 days 0:00:00.000
  24. 1:1174      0 days 0:00:00.000
  25. Kernel Mode Time
  26. Thread       Time
  27. 0:890       0 days 0:00:00.062
  28. 2:a00       0 days 0:00:00.000
  29. 1:1174      0 days 0:00:00.000
  30. 0:002> !runaway 4
  31. Elapsed Time
  32. Thread       Time
  33. 0:890       0 days 0:38:34.825
  34. 1:1174      0 days 0:38:34.793
  35. 2:a00       0 days 0:38:24.528
  36. 0:002> !runaway 7
  37. User Mode Time
  38. Thread       Time
  39. 0:890       0 days 0:00:00.031
  40. 2:a00       0 days 0:00:00.000
  41. 1:1174      0 days 0:00:00.000
  42. Kernel Mode Time
  43. Thread       Time
  44. 0:890       0 days 0:00:00.062
  45. 2:a00       0 days 0:00:00.000
  46. 1:1174      0 days 0:00:00.000
  47. Elapsed Time
  48. Thread       Time
  49. 0:890       0 days 0:38:41.825
  50. 1:1174      0 days 0:38:41.793
  51. 2:a00       0 days 0:38:31.528

该扩展命令可以用来快速找出哪些线程循环失去控制消耗了太多CPU时间。输出中以调试器的内部线程号和16进制线程ID来标识每个线程。还会显示调试器ID,当然,主要用于分析dump文件

~

波形符(~) 命令显示指定线程或当前进程中的所有线程的信息

这条命令显示所有线程

0:001> ~

该命令也显示所有线程。

0:001> ~*

下面的命令显示当前活动线程。

0:001> ~.

下面的命令显示原始的产生异常的线程(或调试器附加到进程时活动的线程)。

0:001> ~#

下面显示号码为2的线程。

0:001> ~2

  1. <span style="color:#000000;">0:002> ~
  2. 0  Id: 17a4.eb4 Suspend: 1 Teb: 7ffdf000 Unfrozen
  3. 1  Id: 17a4.d4c Suspend: 1 Teb: 7ffde000 Unfrozen
  4. .  2  Id: 17a4.aac Suspend: 1 Teb: 7ffdd000 Unfrozen
  5. 0:002> ~*
  6. 0  Id: 17a4.eb4 Suspend: 1 Teb: 7ffdf000 Unfrozen
  7. Start: calc!WinMainCRTStartup (01012475)
  8. Priority: 0  Priority class: 32  Affinity: f
  9. 1  Id: 17a4.d4c Suspend: 1 Teb: 7ffde000 Unfrozen
  10. Start: winimhc!TGetLogConfig+0x507b (10012f7b)
  11. Priority: 0  Priority class: 32  Affinity: f
  12. .  2  Id: 17a4.aac Suspend: 1 Teb: 7ffdd000 Unfrozen
  13. Priority: 0  Priority class: 32  Affinity: f
  14. 0:002> ~0
  15. 0  Id: 17a4.eb4 Suspend: 1 Teb: 7ffdf000 Unfrozen
  16. Start: calc!WinMainCRTStartup (01012475)
  17. Priority: 0  Priority class: 32  Affinity: f
  18. 0:002> ~#
  19. .  2  Id: 17a4.aac Suspend: 1 Teb: 7ffdd000 Unfrozen
  20. Priority: 0  Priority class: 32  Affinity: f</span>

我们可以发现,~和~*还是有点区别的,~*会把入口函数和优先级都打印出来,

0 Id: 17a4.eb4 Suspend: 1 Teb: 7ffdf000 Unfrozen意思是0号线程,进程ID为17a4,线程ID为eb4,暂停数为1,未冻结状态

,每个线程都包含了一个暂停计数(Suspend Count),以及一个冻结/解冻(Frozen/Unfrozen)的状态。



暂停计数由Windows内核使用的值,可以通过SuspendThread和ResumeThread这两个系统函数来控制的,核心编程里说一个线程创建时,暂停次数为1,

当线程完全初始化后,系统就要查看CREATE_SUSPEND标志是否已经传递给CreateThread。如果该标志没有传递,系统便将线程的暂停计数递减为0,

该线程可以调度到一个进程中

也可以用~<tid>n增加暂停计数,用~<tid>m减少暂停计数,如下:

  1. 0:002> ~0n
  2. 0:002> ~
  3. 0  Id: 17a4.eb4 Suspend: 2 Teb: 7ffdf000 Unfrozen
  4. 1  Id: 17a4.d4c Suspend: 1 Teb: 7ffde000 Unfrozen
  5. .  2  Id: 17a4.aac Suspend: 1 Teb: 7ffdd000 Unfrozen
  6. 0:002> ~0m
  7. 0:002> ~
  8. 0  Id: 17a4.eb4 Suspend: 1 Teb: 7ffdf000 Unfrozen
  9. 1  Id: 17a4.d4c Suspend: 1 Teb: 7ffde000 Unfrozen
  10. .  2  Id: 17a4.aac Suspend: 1 Teb: 7ffdd000 Unfrozen
  11. 0:002> ~0m
  12. 0:002> ~
  13. 0  Id: 17a4.eb4 Suspend: 0 Teb: 7ffdf000 Unfrozen
  14. 1  Id: 17a4.d4c Suspend: 1 Teb: 7ffde000 Unfrozen
  15. .  2  Id: 17a4.aac Suspend: 1 Teb: 7ffdd000 Unfrozen
  16. 0:002> ~1m
  17. 0:002> ~
  18. 0  Id: 17a4.eb4 Suspend: 0 Teb: 7ffdf000 Unfrozen
  19. 1  Id: 17a4.d4c Suspend: 0 Teb: 7ffde000 Unfrozen
  20. .  2  Id: 17a4.aac Suspend: 1 Teb: 7ffdd000 Unfrozen

比如我只调用一次~0n,那么主线程的引用计数变为2了,我再调用g,主线程的引用计数变为1,我们的calc是运行不起来的!

冻结状态是调试器的状态,在window操作系统中是不支持这个概念,对于每个被冻结的线程,调试器将记住这个状态,并且在调试事件被处理之前增加线程的挂起计数,当调试事件被处理完毕时,挂起计数将被递减,对应的命令为:

冻结~<tid>f

解冻~<tid>u

冻结命令数量必须和解冻命令数量相等

Windbg 调试CPU占用过高的更多相关文章

  1. WinDbg调试CPU占用高的问题 试验+实战 《第七篇》

    一.High CPU试验 1.示例代码 static void Main(string[] args) { Console.Clear(); Console.WriteLine("到命令行下 ...

  2. Android去除CPU占用过高时屏幕四周闪红框

    话说有些时间没有更新博客了,今天正好解决这个问题,顺便把它记录下来.. 今天遇到的情况是这样的,当CPU占用过高时,屏幕四周会出现一个红框. 闪一次两次算了,但是挺萌的(TMD)不停的闪,我的钛合金狗 ...

  3. 性能测试问题_Mysql数据库服务器的CPU占用很高

    MySQl服务器CPU占用很高 1.  问题描述 一个简单的接口,根据传入的号段查询号码归属地,运行性能测试脚本,20个并发mysql的CPU就很高,监控发现只有一个select语句,且表建立了索引 ...

  4. Atitit. 最佳实践 QA----减少cpu占有率--cpu占用太高怎么办

    Atitit. 最佳实践 QA----减少cpu占有率--cpu占用太高怎么办 跟个磁盘队列长度雅十,一到李80%走不行兰.... 1. 寻找线程too 多的.关闭... Taskman>> ...

  5. 一次java Cpu占用过高的排查

    某一个项目CPU占用率一直很高,经常在40%-50%之间,最近比较闲,就开始了排查工作. 1.通过 jstack命令输出进程的堆栈信息 jstack 2788 >C:\log.txt 将堆栈信息 ...

  6. java 一次CPU占用过高问题的排查及解决

    最近一段时间  某台服务器上的一个应用总是隔一段时间就自己挂掉      用top看了看  从重新部署应用开始没有多长时间CPU占用上升得很快 排查步骤 1.使用top 定位到占用CPU高的进程PID ...

  7. “RESOURCE MONITOR“CPU占用特别高

    背景: SQL Server 2008 R2 10.50.1600 没有设置页面文件,内存为64G,数据库分配50G cpu使用占了50%以上,平时只有10-20%,某台服务器“RESOURCE MO ...

  8. kswapd0 进程CPU占用过高

    前几天遇到的一个问题,自己本地用VM配置的虚拟机,一般会top查看进程以及CPU占用的一些情况.又一次用laravel 打印对象,里面的内容比较多,浏览器当时就卡了. 然后看进程的情况.我以为会是ng ...

  9. 工具运行过程中,CPU占用过高的分析定位

    之前使用Java Swing开发了一款设备档案收集工具.支持多台设备同时收集,每个设备使用一个线程.在同时收集多台设备信息时,发现CPU占用率居然达到了97%,而且高居不下.显然这样的性能是令人无法忍 ...

随机推荐

  1. centos7 安装KDE

    下载安装了centos7 64位系统之后.初始化安装的是GNOME桌面系统.因为是按照鸟哥的Linux在学习,所以需要安装kde. 首先需要root权限. 打开终端. 输入su root密码.进入ro ...

  2. 【代码工具】Lombok来优雅的编码

    前言 Lombok 是一种 Java™ 实用工具,可用来帮助开发人员消除 Java 的冗长,尤其是对于简单的 Java 对象(POJO).它通过注解实现这一目的. 正文 添加依赖 在 pom.xml ...

  3. DataWorks2.0的“业务流程”与1.0的“工作流”的对比

    DatwWorks终于升级2.0了,心情万分激动之余,又有一丝担忧.因为,没法再创建新的旧版工作流了...新版抛弃了“工作流”这个概念,引入了“业务流程”和“解决方案”两个新的概念.于是,作为团队Le ...

  4. js实现canvas保存图片为png格式并下载到本地

    canvas 保存图片 下载到本地 function base64Img2Blob(code){ var parts = code.split(';base64,'); var contentType ...

  5. 好用的日期控件jeDate

    最近做公司后台系统关于仓库的一些东西,需要根据时间范围来导出一些数据,我们使用的后台框架是基于bs的,bs也有时间控件:bootstrap-datepicker是只能选择日期的, daterangep ...

  6. 使用Docker在服务器上部署Ubuntu,本地传文件到docker

    使用Docker在服务器上部署Ubuntu,本地传文件到docker 作者:王佳乐 目录 安装Docker 安装Docker 全部安装流程: 登录服务器 ssh username@ip 检查是否已经安 ...

  7. 大神给你分析HTTPS和HTTP的区别

    今天在做雅虎的时候,发现用第三方工具截取不到客户端与服务端的通讯,以前重来没碰到过这种情况,仔细看了看,它的url请求时基于https的,gg了下发现原来https协议和http有着很大的区别.总的来 ...

  8. 《DSP using MATLAB》Problem 9.4

    只放第1小题. 代码: %% ------------------------------------------------------------------------ %% Output In ...

  9. js 关闭页面(Scripts may close only the windows that were opened by it.)

    传送http://blog.csdn.net/kuangfengbuyi/article/details/52052301 js关闭当前页面,当该页面不是其他页面打开的,而是直接输入url, 直接用w ...

  10. java_MySQL未整理

    package cn.aikang.MySql; public class MySqlTest {/*数据库的基本概念: 1.数据库的英文单词:DataBase简称:DB 2.什么是数据库:用于存储和 ...