.NET 10 - Blazor web assembly应用的一些诊断方式

1. 简单介绍

.NET Conf 2025(2025/11/11-2025/11/14)已经结束了,微软发布了.NET10Visual Studio 2026

.NET 10 是Long term support版本, 微软将支持到2028年。

AI 依然是这次大会非常重要的主题,不过感觉没有2024年的.NET Conf来的那么浓重。基于之前的Semantic Kernel和Autogen,微软推出了Microsoft Agent Framework。大会中很多的演示系统是基于.NET Aspre制作的。

Blazor是作为一个独立的session进行讲解,大会中微软老师将Blazor的更新分成了4个方面

  1. Security

  2. Observability & diagnostics

  3. Performance improvements

  4. Delight developers

其中Observability & diagnostics方面的更新有New metrics, Improved tracing, Blazor WebAssembly diagnostic tools。

这边简单体验一下Blazor WebAssembly diagnostic tools的使用

2.具体说明

假定已经安装了Visual Studio 2026和.NET Sdk 10.0,并创建了一个Blazor web assembly项目,

2.1 安装wasm-tools

如果要使用Blazor Web Assembly diagnostic tool,则需要先安装一下 wasm-tools,命令如下

复制代码
dotnet workload install wasm-tools

2.2 配置项目

在Client项目文件中(.csproj)添加如下配置,

复制代码
<PropertyGroup>
  <EnableDiagnostics>true</EnableDiagnostics>
</PropertyGroup>

note, 这个配置适用于开发阶段,生成环境不应该做这个配置的。

2.3 Dump Memory

  1. 启动项目,导航到有问题的页面或者组件,通过调用Javascript Api collectGcDump来执行一下memory dump操作,如下图所示,

    globalThis.getDotnetRuntime(0).collectGcDump();

  1. 命令会生成一个.nettrace后缀的文件,

3)执行如下命令对.nettrace后缀文件进行转换,

复制代码
dotnet gcdump convert trace.1763561149130.nettrace

转换后的文件如下图所示,

4).gcdump后缀的文件可以使用Visual Studio 2026直接打开并进行问题的diagnositc了,

note, 以上的memory dump方法适用于检查内容泄露问题。

2.4 检查方法的效率

从CPU的角度可以查看各个方法执行的快慢,可以使用Javascript Api collectCpuSamples

  1. 配置项目,

2)启动项目,导航到有问题的页面或者组件,执行如下命令获取60秒内CPU的执行数据

复制代码
globalThis.getDotnetRuntime(0).collectCpuSamples({durationSeconds: 60});
  1. 使用Visual Studio 2026或者PrefView打开.nettrace文件进行检查分析。

2.5 其他

还可以通过如下的Javascript 命令collectMetrics获取Blazor app的metric数据,

复制代码
globalThis.getDotnetRuntime(0).collectMetrics({durationSeconds: 5});

对应的csproj文件中需要添加如下的配置,

3.总结

本文简单介绍了一下.NET 10中Blazor Web Assembly应用程序问题诊断和排查的一些方式,通过collectGcDump,collectCpuSamples,collectMetrics可以获取nettrace执行数据以便进行问题分析。.NET 10 中Blazor的更新有很多,还需要继续跟着微软的老师学习一下。

本文如果哪里有错误,麻烦告之,谢谢谢谢!

相关推荐
玩泥巴的9 小时前
飞书 .NET SDK 事件处理的幂等性与去重机制
c#·.net·二次开发·飞书
在路上看风景9 小时前
3.2 FileStream
c#
zwm2698888159 小时前
6号楼 部分声光24v电压达不到,显示11v
c#
喵叔哟10 小时前
20.部署与运维
运维·docker·容器·.net
椒颜皮皮虾13 小时前
TensorRtSharp:在 C# 世界中释放 GPU 推理的极致性能
c#·tensorrt
行止9513 小时前
WinForms 彻底隐藏 滚动条的终极解决方案
c#
bugcome_com14 小时前
WPF样式进阶实战:外置样式+MVVM主题切换+样式优先级全解析
c#·.net·wpf
时光追逐者14 小时前
TIOBE 公布 C# 是 2025 年度编程语言
开发语言·c#·.net·.net core·tiobe
观无15 小时前
固高运动控制卡(GST800)基础应用分享
c#
flysh0516 小时前
如何利用 C# 内置的 Action 和 Func 委托
开发语言·c#