培训
模块
使用 Visual Studio Code 调试器以交互方式调试 .NET 应用 - Training
了解如何使用 Visual Studio Code 快速修复 bug 来有效地调试 .NET 应用。 使用 Visual Studio Code 中的交互式调试器分析和修复 C# 应用程序。
本文适用于:✔️ dotnet-stack
版本 5.0.221401 及更高版本
可采用两种方法来下载和安装 dotnet-stack
:
dotnet 全局工具:
若要安装最新版 dotnet-stack
NuGet 包,请使用 dotnet tool install 命令:
dotnet tool install --global dotnet-stack
直接下载:
下载与平台相匹配的工具可执行文件:
dotnet-stack [-h, --help] [--version] <command>
dotnet-stack
工具:
EventPipe
跟踪。-h|--help
显示命令行帮助。
--version
显示 dotnet-stack 实用工具的版本。
命令 | 说明 |
---|---|
dotnet-stack 报告 | 打印目标进程中每个线程的堆栈跟踪。 |
dotnet-stack ps | 列出可从中收集堆栈跟踪的 dotnet 进程。 |
dotnet-stack 符号化 | 从堆栈跟踪中的方法标记和 IL 偏移量中获取行号。 |
打印目标进程中每个线程的堆栈跟踪。
dotnet-stack report -p|--process-id <pid>
-n|--name <process-name>
[-h|--help]
-n, --name <name>
要从中报告堆栈的进程的名称。
-p|--process-id <PID>
要从中报告堆栈的进程 ID。
列出可从中收集堆栈跟踪的 dotnet 进程。
dotnet-stack
版本 6.0.320703 及更高版本还显示每个进程的启动命令行参数(如果可用)。
dotnet-stack ps [-h|--help]
假设使用命令 dotnet run --configuration Release
启动长时间运行的应用。 在另一个窗口中,运行 dotnet-stack ps
命令。 你将看到如下输出。 命令行参数(如果有)显示在 dotnet-stack
版本 6.0.320703 及更高版本中。
> dotnet-stack ps
21932 dotnet C:\Program Files\dotnet\dotnet.exe run --configuration Release
36656 dotnet C:\Program Files\dotnet\dotnet.exe
从堆栈跟踪中的方法标记和 IL 偏移量中获取行号。
dotnet-stack symbolicate <input-path> [-d|--search-dir] [-o|--output] [-c|--stdout] [-h|--help]
-d, --search-dir <directory1 directory2 ...>
具有程序集和 pdb 的多个目录的路径。
-o, --output <output-path>
直接输出到文件。
-c, --stdout
直接输出到控制台。
> cat stack.trace
Unhandled exception. System.NullReferenceException: Object reference not set to an instance of an object.
at DotnetStackSymbolicate.App.MethodA() in DotnetStackSymbolicate.dll:token 0x6000002+0x6
at DotnetStackSymbolicate.App..ctor() in DotnetStackSymbolicate.dll:token 0x6000003+0x51
at DotnetStackSymbolicate.Program.OnCreate() in DotnetStackSymbolicate.Tizen.dll:token 0x6000001+0x8
onSigabrt called
>
> dotnet-stack symbolicate stack.trace --stdout
Unhandled exception. System.NullReferenceException: Object reference not set to an instance of an object.
at DotnetStackSymbolicate.App.MethodA() in C:\DotnetStackSymbolicate\DotnetStackSymbolicate.cs:line 19
at DotnetStackSymbolicate.App..ctor() in C:\DotnetStackSymbolicate\DotnetStackSymbolicate.cs:line 38
at DotnetStackSymbolicate.Program.OnCreate() in C:\DotnetStackSymbolicate.Tizen\DotnetStackSymbolicate.Tizen.cs:line 12
onSigabrt called
Output: stack.trace.symbolicated
使用 dotnet-stack
报告托管堆栈:
获取要从中报告堆栈的 .NET Core 应用程序的进程标识符 (PID)。
tasklist
命令。ps
命令。运行下面的命令:
dotnet-stack report --process-id <PID>
前面的命令生成类似于以下内容的输出:
Thread (0x48839B):
[Native Frames]
System.Console!System.IO.StdInReader.ReadKey(bool&)
System.Console!System.IO.SyncTextReader.ReadKey(bool&)
System.Console!System.ConsolePal.ReadKey(bool)
System.Console!System.Console.ReadKey()
StackTracee!Tracee.Program.Main(class System.String[])
dotnet-stack
的输出遵循以下格式:
#
为前缀。Thread (<thread-id>):
。Module!Method
。[Native Frames]
。# comment
Thread (0x1234):
module!Method
module!Method
Thread (0x5678):
[Native Frames]
Module!Method
Module!Method
备注
对于非常大的应用程序,停止该进程可能需要很长的时间(长达几分钟)。 运行时需要发送捕获的所有托管代码的类型和方法信息来解析函数名称。
培训
模块
使用 Visual Studio Code 调试器以交互方式调试 .NET 应用 - Training
了解如何使用 Visual Studio Code 快速修复 bug 来有效地调试 .NET 应用。 使用 Visual Studio Code 中的交互式调试器分析和修复 C# 应用程序。