当前位置: 首页 > news >正文

学习使用dotnet-dump工具分析.net内存转储文件(2)

  运行ShenNiusModularity项目,使用createdump工具dump完整的进程内存映射文件,然后运行dotnet-dump analyze命令加载dump文件。
  可以先使用dumpheap命令显示有关垃圾回收堆的信息和有关对象的收集统计信息。dumpheap支持多类参数(如下所示):

DumpHeap [-stat][-strings][-short][-min <size>][-max <size>][-live][-dead][-thinlock][-startAtLowerBound][-mt <MethodTable address>][-type <partial type name>][start [end]]

  常用的参数包括:
  1)-stat:显示对象数量、总大小及类型名称,如下图所示,该参数从小到大返回dump文件中每种类型的对象数量、总大小,可以从返回结果中看到内存占用异常或者数量异常的数据类型;在这里插入图片描述
  2)-mt:查看方法表对应的类型的对象列表,一般用-stat看到数量异常或内存异常的类型后,用该参数再加上该类型的MT地址查看详细的对象列表(也可以用-type 及类型名称查看);
在这里插入图片描述
  3)-strings:针对字符串类型,统计字符串值的出现次数,如果字符串太多,可以考虑用-min、-max参数限制数据范围;
在这里插入图片描述
  4)-min/-max:设置仅显示大于/小于指定字节大小的对象;
  5)-type:作用同mt参数,仅将MT地址换为类型名称,可以仅输入部分名称;
  6)-short:仅输出对象地址。

  从dumpheap -mt的列表中找到可疑的对象地址,然后使用dumpobj命令查看对象内容,如下图所示:
在这里插入图片描述
参考文献:
[1]https://learn.microsoft.com/zh-cn/dotnet/core/diagnostics/dotnet-dump
[2]https://www.nuget.org/packages/dotnet-dump

相关文章:

  • OpenLayers 下载地图切片
  • Python 中定义和调用函数:基础与进阶指南
  • 《从 0 到 1 掌握正则表达式:解析串口数据的万能钥匙》
  • 【EDA软件】【联合Modelsim 同步FIFO仿真】
  • GitHub 趋势日报(2025年06月27日)
  • 雷卯针对灵眸科技EASY EAI nano RV1126 开发板防雷防静电方案
  • 复杂驱动开发-TLE9471的休眠流程与定时唤醒
  • DMA之 Trigger input和 Trigger Output 概念
  • 具身智能系列教程——(一)具身智能研究与发展
  • 户外人像要怎么拍 ?
  • 【Docker基础】Docker容器管理:docker top及其参数详解
  • electron中显示echarts
  • 【NLP】自然语言项目设计03
  • 关于ubuntu 20.04系统安装分区和重复登录无法加载桌面的问题解决
  • 【数据标注】事件标注1
  • Vue工程化实现约定式路由自动注册
  • Go开发工程师-Golang基础知识篇
  • 数据结构:最小生成树—Prim(普里姆)与Kruskal(克鲁斯卡尔)算法
  • 什么是哈希链(Hash Chain)?
  • Redis 实现分布式锁