dump-collect

.NET Crash Dump Collection

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "dump-collect" with this command: npx skills add dotnet/skills/dotnet-skills-dump-collect

.NET Crash Dump Collection

This skill configures and collects crash dumps for modern .NET applications (CoreCLR and NativeAOT) on Linux, macOS, and Windows — including containers.

Stop Signals

🚨 Read before starting any workflow.

  • Stop after dumps are enabled or collected. Do not open, analyze, or triage dump files.

  • If the user already has a dump file, this skill does not cover analysis. Let them know analysis is out of scope.

  • Do not install analysis tools (dotnet-dump analyze, windbg). Only install collection tools (dotnet-dump collect). Using lldb for on-demand dump capture on macOS is allowed — it ships with Xcode command-line tools and is not being used for analysis.

  • Do not trace root cause of crashes. Report the dump file location and move on.

  • Do not modify application code. Configuration is environment-only (env vars, OS settings, container specs).

Step 1 — Identify the Scenario

Ask or determine:

  • Goal: Enable automatic crash dumps, or capture a dump from a running process right now?

  • Platform: Linux, macOS, or Windows? Running in a container (Docker/Kubernetes)?

  • Runtime: CoreCLR or NativeAOT?

Detecting CoreCLR vs NativeAOT

From a binary file (Linux/macOS):

CoreCLR — has IL metadata / managed entry point

strings <binary> | grep -q "CorExeMain" && echo "CoreCLR"

NativeAOT — has Redhawk runtime symbols

strings <binary> | grep -q "Rhp" && echo "NativeAOT"

On macOS/Linux, also try:

nm <binary> 2>/dev/null | grep -qi "Rhp" && echo "NativeAOT"

From a binary file (Windows):

CoreCLR — has a CLI header (IL entry point)

dumpbin /clrheader <binary.exe> | Select-String "CLI Header" -Quiet

NativeAOT — no CLI header, has Redhawk symbols

dumpbin /symbols <binary.exe> | Select-String "Rhp" -Quiet

From a running process (Linux):

Resolve the binary, then use the same file checks

BINARY=$(readlink /proc/<pid>/exe) strings "$BINARY" | grep -q "CorExeMain" && echo "CoreCLR" || echo "NativeAOT"

From a running process (macOS):

Resolve the binary path from the running process

BINARY=$(ps -o comm= -p <pid>) strings "$BINARY" | grep -q "CorExeMain" && echo "CoreCLR" || echo "NativeAOT"

From a running process (Windows PowerShell):

CoreCLR — loads coreclr.dll

(Get-Process -Id <pid>).Modules.ModuleName -contains "coreclr.dll"

.NET Framework — loads clr.dll (this skill does not apply)

(Get-Process -Id <pid>).Modules.ModuleName -contains "clr.dll"

If the app is .NET Framework (clr.dll ), stop. This skill covers modern .NET (CoreCLR and NativeAOT) only.

If neither CoreCLR nor NativeAOT is detected, stop. This skill only applies to .NET applications — do not proceed.

Step 2 — Load the Appropriate Reference

Based on the scenario identified in Step 1, read the relevant reference file:

Scenario Reference

CoreCLR app (any platform) references/coreclr-dumps.md

NativeAOT app (any platform) references/nativeaot-dumps.md

Any app in Docker or Kubernetes references/container-dumps.md (then also load the runtime-specific reference)

Step 3 — Execute

Follow the instructions in the loaded reference to configure or collect dumps. Always:

  • Confirm the dump output directory exists and has write permissions before enabling collection.

  • Report the dump file path back to the user after collection succeeds.

  • Verify configuration took effect — for env vars, echo them; for OS settings, read them back.

  • Remind the user to disable automatic dumps if they were enabled temporarily — remove or unset DOTNET_DbgEnableMiniDump and related env vars to avoid accumulating dump files.

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

dotnet

No summary provided by upstream source.

Repository SourceNeeds Review
General

analyzing-dotnet-performance

No summary provided by upstream source.

Repository SourceNeeds Review
General

csharp-scripts

No summary provided by upstream source.

Repository SourceNeeds Review