学习使用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