.NET Core 如何调试 CPU 爆高?

在这篇文章中我们将会分析一个 CPU 爆高的案例,测试demo链接 :https://docs.microsoft.com/en-us/samples/dotnet/samples/diagnostic-scenarios/ 。

你将会学到:

  1. 如何使用 dotnet-counters 确定真实的 cpu 使用率。

  2. 使用 dotnet-trace 追踪代码。

  3. 使用 PerfView 寻找问题代码并解决。

确定CPU使用率

首先运行案例程序,参考如下代码:

dotnet run

接下来使用如下命令找到 netcore 程序的 pid。

dotnet-trace ps

值得注意的是,我这里的 pid=22884, 你的可能不一样,然后用 dotnet-counters 工具收集当前 cpu 爆高的状态数据,参考如下命令。

dotnet-counters monitor --refresh-interval 1 -p 22884

这里的 refresh-interval 表示刷新间隔,接下来你会得到如下输出。

Press p to pause, r to resume, q to quit.Status: Running[System.Runtime]% Time in GC since last GC (%)                         0Allocation Rate / 1 sec (B)                            0CPU Usage (%)                                          0Exception Count / 1 sec                                0GC Heap Size (MB)                                      4Gen 0 GC Count / 60 sec                                0Gen 0 Size (B)                                         0Gen 1 GC Count / 60 sec                                0Gen 1 Size (B)                                         0Gen 2 GC Count / 60 sec                                0Gen 2 Size (B)                                         0LOH Size (B)                                           0Monitor Lock Contention Count / 1 sec                  0Number of Active Timers                                1Number of Assemblies Loaded                          140ThreadPool Completed Work Item Count / 1 sec           3ThreadPool Queue Length                                0ThreadPool Thread Count                                7Working Set (MB)                                      63

从输出看,当前的 cpu=0,现在可以让 cpu 爆高起来了,输入链接:api/diagscenario/highcpu/60000 ,然后重新运行下 dotnet-counters ,启动时指定 System.Runtime[cpu-usage] 参数表示我们只捕获 cpu-usage 指标。

dotnet-counters monitor --counters System.Runtime[cpu-usage] -p 22884 --refresh-interval 1

不出意外,你会看到 cpu使用率 上去了。

Press p to pause, r to resume, q to quit.Status: Running[System.Runtime]CPU Usage (%)                                         25

可以看到,cpu使用率已经高达 25% 了,到这里我认为这个 cpu 使用率已经超出了我的预期,接下来就需要进行代码追踪了。

收集运行代码数据

接下来用 dotnet-trace 作为收集工具,运行如下命令。

dotnet-trace collect -p 22884 --providers Microsoft-DotNETCore-SampleProfiler

dotnet-trace 运行大概 20-30s,然后键入 Enter 退出,你会看到当前目录有一个 nettrace 文件,接下来就可以用 PrefView 对 nettrace 进行分析啦。

abaa76bff234bc5a64bff57b1d718dfe.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/296561.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[OIBH] 糖果盒(Candy Box)——又一个最大子矩形

http://codewaysky.sinaapp.com/problem.php?id1056 这题和奶牛浴场略有区别,奶牛浴场只需要求出最大子矩形,而这题要求的是最大权重子矩形,不一定要最大的面积,但要最大的权重和 思路是先求出每个最大子矩形,然后求出…

百度面试

1 算法:写LRU算法 2 算法思想,二维矩阵中查找一个数,矩阵的按行递增和按列递增。 3 将int i的一个数转换为大端形式,例如0x1a2b3c4d为0x4d3c2b1a。 4 已知一随机发生器,产生0的概率是p,产生1的概率是1-p&am…

日本第一赘婿!他入赘近20年拿下诺贝尔奖,成名后不忘教光棍讨老婆......

全世界只有3.14 % 的人关注了爆炸吧知识谁能凭感性要诺贝尔奖私有1949年12月10号,日本民众发出了暌违多年的欢呼声,因为诺贝尔奖史无前例地颁给了一位日本物理学家——汤川秀树。报道汤川秀树获奖新闻的报纸获奖后,在自传《旅人:一…

xs128 双定时器PIT0和PIT1

/***************************************************************** ** 函数说明:xs128 双定时器PIT0和PIT1 ** 版 本:V1.00 ** 修 改:庞辉 芜湖联大飞思卡尔工作室 …

修改mongodb最大查询数_WebFlux系列(十二)MongoDB应用,新增、修改、查询、删除

#Java#Spring#SpringBoot#Mongo#reactor#webflux#数据库#新增#修改#查询#删除#Spring Boot WebFlux Mongo数据库新增、删除、查询、修改视频讲解 : https://www.bilibili.com/video/av84240038/Employee.javapackage com.example.spring.webfluxmongo;import lombok.AllArgsCon…

如何捕获 EF 生成的 SQL 脚本?

咨询区 nos:请问我如何查看 entity framewrok 生成的 SQL 脚本,我用的是 MySQL Provider 。回答区 Nick Berardi:你可以像下面这样做:IQueryable query from x in appEntitieswhere x.id 32select x;var sql ((System.Data.Obj…

函数体中的全局变量与局部变量

首先看一道笔试题: 1 var a 100; 2 function testResult(){ 3 var b 2 * a; 4 var a 200; 5 var c a / 2; 6 alert(b); 7 alert(c); 8 } 9 testResult(); 输出结果为:NaN和100; 因为当全局变…

笔试题 遗忘点记录 面向对象特点 + 产生死锁条件+ windows内存管理方法

)单一职责原则。就一个类而言,应该仅有一个引起它变化的原因。 //感觉这个是 低耦合 高内聚 (2)开放封闭原则。软件实体对外扩展开放,对修改封闭。 //这个基础。。 &am…

为什么每个理发店门口都有彩色的柱子?你不知道吧

全世界只有3.14 % 的人关注了爆炸吧知识为什么街上的理发店门口都有一根旋转着的彩色灯柱?好学的小编忍不住去寻找真相...理发店门口彩色的柱子这根彩柱与医疗有关彩柱通常是3种颜色,白红蓝。一般认为:白色绷带,红色绷带上的血(动…

前台jsp页面向后台传汉字出现乱码问题解决办法

如下&#xff1a; jsp页面代码&#xff1a; var groupsName"全体技能组"; window.location.href encodeURI("<%path%>/CustomersServletmethodservice_95518_telephone&provinceCode"provinceCode"&cityCode"cityCode"…

是否显示展开_Creo7.0教程之绝对精度对钣金件展开的作用详解

在讲Creo7.0绝对精度对钣金展开的帮助之前&#xff0c;我们有必要先来说明一下Creo的精度定义。刚使用Creo7.0版本的新建模型&#xff0c;很多网友就问&#xff0c;怎么模板文件中有两个同样单位的选择&#xff0c;“abs”和“rel”有什么区别&#xff1f;新建文件选项其实这就…

UrlRewrite(Url重写技术)

ASP.NET伪静态 UrlRewrite(Url重写) 实现和配置------转载 ASP.NET伪静态 UrlRewrite(Url重写) 实现和配置 核心提示&#xff1a;大家一定经常在网络上看到很多网站的地址后缀都是用XX.HTML或者XX.ASPX等类似静态文件的标示来操作的吧&#xff0c;那么大家有怀疑过他真的是一个…

“快准顺”而不是“信达雅”

在今年夏天策马翻译举办的翻译讲座上&#xff0c;我和詹成教授交流过一个问题&#xff1a;詹教授讲的很多知识点和经验并不符合“信达雅”&#xff1f;詹教授的回答是&#xff1a;“信达雅”并非翻译界的标准&#xff0c;他自己在日常翻译工作中的标准是“快准顺”。詹教授的回…

知乎点赞超过10万的科学脱单法!这绝对是我见过最硬核的撩妹套路......

全世界只有3.14 % 的人关注了爆炸吧知识科学脱单硬核撩妹前两天&#xff0c;超模君在知乎上看到一个热门的问答&#xff1a;开学后如何快速找到对象&#xff1f;这个话题&#xff0c;让超模君回想起了当年刚进入大学的那会儿&#xff0c;校园中秀恩爱的情侣无处不在&#xff0c…

二叉树的非递归遍历

非递归实现二叉树的前序/后序/中序遍历 中序遍历 // arr[1]// arr[2] arr[3] // arr[4] arr[5] arr[6] // arr[7] arr[8]如上数据, 以栈来代替递归实现,输出为4,2,(遍历右元素7,5,8).那么就要想办法以上面的方法入栈4,2…

InfoQ宣布成立CNUT容器技术俱乐部 欲连接中国容器社区

2015年8月28日&#xff0c;首届CNUTCon全球容器技术大会在北京举行。在大会上&#xff0c;极客邦科技与InfoQ中国创始人兼CEO霍泰稳宣布&#xff0c;InfoQ联合国内一线IT技术公司共同成立CNUT容器技术俱乐部&#xff0c;连接中国容器技术社区&#xff0c;推动容器技术以及开源在…

office 高效办公智慧树_干货高效实用的office办公小技巧之word篇

对于office三剑客ppt、Word、Excel的使用成了日常&#xff0c;作为办公党&#xff0c;今天就拿出自己在平时工作之中发现、学到的小技巧来做个总结&#xff0c;分享给大家。相信很多大神对于这些小技巧都已经精通&#xff0c;所以lz会先列出目录&#xff0c;大家可以自行依据目…

POJ 1904 【强连通分量】.cpp

题意&#xff1a; 很久很久以前.. 有一个国王.. 他有好几个儿子.. 这些王子都喜欢上了邻国的公主.. 他们准备迎娶自己喜欢的公主中的一个.. 国王就让宰相给列一个清单.. 宰相就给了国王一个清单..上面写明了哪个王子将迎娶哪个邻国的公主.. 但是调皮的国王不太满意~~ 他还想知道…

电梯里为什么放镜子?90%的人都不知道

全世界只有3.14 % 的人关注了爆炸吧知识随着高层建筑不断的拔地而起我们每天可能会上下十几层的高楼人们当然不想去爬楼梯所以电梯已成为生活中必不可少的一部分▼我们几乎每天都会坐电梯上班时、回家时、逛街时当我们每走进电梯时第一动作都会干什么呢大概都会先看自己的妆容再…

WPF中的命令(Command)

这节来讲一下WPF中的命令(Command)的使用。【认识Command】我们之前说过&#xff0c;WPF本身就为我们提供了一个基础的MVVM框架&#xff0c;本节要讲的命令就是其中一环&#xff0c;通过在ViewModel中声明命令&#xff0c;从View中使用Binding绑定命令&#xff0c;就能实现从Vi…