6

使用Visual Studio分析dump

 3 years ago
source link: https://www.cnblogs.com/Cyril-hcj/p/15207214.html
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

最近系统时不时CPU会飙升的百分之九十多甚至百分百,在本地又很难复现问题,无法定位问题出现在哪。

可以用转储文件来保存现场,然后通过分析dump文件可以大概分析出问题的所在

生成转存文件

在CPU飙升时打开任务管理器,找到对应的进程(IIS Worker Process),右键然后点击创建转储文件

使用Visual Studio打开dump文件

选择要分析的.dmp文件,右键使用vs执行

 分析dump文件

可参考微软官方文档:https://docs.microsoft.com/zh-cn/visualstudio/debugger/how-to-debug-managed-memory-dump?view=vs-2022

点击右侧操作下的运行诊断分析,选择要分析的选项然后点击分析

 点击分析结果可查看具体的分析,包括异常对象以及一些大型对象,可通过检查其中的对象来排除代码是否有不当的使用

 由于我们遇到的问题是CPU占用过高的问题,所以着重检查CPU使用率摘要

 可以发现EndProductHandler这个类是使用CPU资源最多的,我们也可以打开并行堆栈来查看方法的调用

最后通过检查分析EndProductHandler发现有个方法在循环生成某个表,然后没有使用EF的批量新增,再通过阿里云的监控台可以看到CPU飙升的那段时间用户刚好在执行此操作。

至此,先将方法修改成批量新增的方法,等后续再观察下还有没有别的问题。

__EOF__

本文作者:Cyril
本文链接:https://www.cnblogs.com/Cyril-hcj/p/15207214.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!

About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK