.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的更新有很多,还需要继续跟着微软的老师学习一下。

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

相关推荐
懒人咖16 小时前
缺料分析时携带用料清单的二开字段
c#·金蝶云星空
bugcome_com17 小时前
深入了解 C# 编程环境及其开发工具
c#
吹牛不交税17 小时前
admin.net-v2 框架使用笔记-netcore8.0/10.0版
vue.js·.netcore
wfserial18 小时前
c#使用微软自带speech选择男声仍然是女声的一种原因
microsoft·c#·speech
阔皮大师20 小时前
INote轻量文本编辑器
java·javascript·python·c#
kylezhao201921 小时前
C# 中的 SOLID 五大设计原则
开发语言·c#
啦啦啦_999921 小时前
Redis-5-doFormatAsync()方法
数据库·redis·c#
Porco.w1 天前
C#与三菱PLC FX5U通信
网络·c#
E_ICEBLUE1 天前
PPT 批量转图片:在 Web 预览中实现翻页效果(C#/VB.NET)
c#·powerpoint·svg
山岚的运维笔记1 天前
SQL Server笔记 -- 第20章:TRY/CATCH
java·数据库·笔记·sql·microsoft·sqlserver