dotnet-asynkron-profiler
Asynkron.Profiler
Trigger On
- the repo wants
Asynkron.Profilerorasynkron-profiler - the user wants automation-friendly profiling output instead of GUI-only tooling
- profiling needs are CPU, allocation, exception, contention, or heap focused and should land as plain-text summaries in CI, scripts, or agent workflows
- the task needs to render an existing
.nettrace,.speedscope.json,.etlx, or.gcdumpfile into a readable report
Workflow
- Decide whether the task is a new profile capture or rendering an existing trace artifact.
- Prefer built
Releaseoutput overdotnet runso the trace represents the target app rather than restore/build noise. - Install and verify all three tools before assuming the profiler is usable:
asynkron-profilerdotnet-tracedotnet-gcdump
- Choose exactly one primary mode first:
--cpu--memory--exception--contention--heap
- Use
--input <path>when the trace already exists and the task is about rendering or narrowing the report, not recollecting data. - Refine the output only after the baseline run:
--root <text>to anchor the call tree--filter <text>to trim tables--exception-type <text>for exception-heavy flows--calltree-depth,--calltree-width,--calltree-self,--calltree-sibling-cutoff
- Treat
profile-output/as the stable output folder for review artifacts and reruns. - If the task needs process attach, counters, or raw official diagnostics flows rather than this CLI frontend, hand off to
dotnet-profiling.
Architecture
flowchart LR
A["Profiling task"] --> B{"New run or existing artifact?"}
B -->|New run| C["Build target in Release"]
C --> D["Run `asynkron-profiler --mode -- <command|csproj|sln>`"]
D --> E["Collect via `dotnet-trace` or `dotnet-gcdump`"]
E --> F["Write reports to `profile-output/`"]
B -->|Existing artifact| G["Run `asynkron-profiler --input <path> [--mode]`"]
G --> F
F --> H["Refine output with `--root`, `--filter`, and call tree flags"]
Install
- Install the profiler tool from upstream:
dotnet tool install -g asynkron-profiler --prerelease
- Install prerequisites:
dotnet tool install -g dotnet-trace
dotnet tool install -g dotnet-gcdump
- Verify the toolchain:
asynkron-profiler --help
dotnet-trace --version
dotnet-gcdump --version
Practical Usage
Capture a new profile
dotnet build -c Release
asynkron-profiler --cpu -- ./bin/Release/<tfm>/MyApp
Framework-dependent apps can run through dotnet:
asynkron-profiler --memory -- dotnet ./bin/Release/<tfm>/MyApp.dll
Project and solution paths are also valid when the tool should build and run for you:
asynkron-profiler --contention -- ./MyApp.csproj
asynkron-profiler --exception -- ./MySolution.sln
Render an existing trace
asynkron-profiler --input ./profile-output/app.nettrace --cpu
asynkron-profiler --input ./profile-output/app.etlx --memory
asynkron-profiler --input ./profile-output/app.gcdump --heap
Manual collection with the official tools still fits when the trace must be captured separately:
dotnet-trace collect --output ./profile-output/app.nettrace -- dotnet run MyProject.sln
asynkron-profiler --input ./profile-output/app.nettrace --cpu
Option Patterns
- mode flags:
--cpufor sampled hotspots--memoryfor GC allocation ticks and per-type call trees--exceptionfor thrown counts and throw-site trees--contentionfor wait-time trees--heapfor retained heap shape viadotnet-gcdump
- scope and readability:
--root <text>to focus the tree on a subsystem--filter <text>to narrow function tables--exception-type <text>when one exception dominates the signal
- output shaping:
--calltree-depth <n>--calltree-width <n>--calltree-self--calltree-sibling-cutoff <n>
- trace replay and project targeting:
--input <path>for.nettrace,.speedscope.json,.etlx, or.gcdump--tfm <tfm>when the profiler must resolve a specific target framework from a.csprojor.sln
Constraints
- upstream currently documents
.NET SDK 10.xas the supported toolchain baseline dotnet runis supported but usually produces noisy traces because it captures host, restore, and build work- the tool is a frontend over
dotnet-traceanddotnet-gcdump, so missing prerequisites or blocked diagnostics IPC will break runs --heapcaptures retained heap shape, not CPU or allocation timelines- this skill is for launched commands or existing trace files; if the task is process attach, counters, or raw trace authoring, prefer
dotnet-profiling
Deliver
- a repeatable
asynkron-profilercommand path for the profiling mode that matches the problem - explicit install and prerequisite commands
- a clear baseline command plus any focused
--root,--filter,--exception-type, or call-tree options needed for readable output - trace replay guidance when the task starts from an existing artifact
Validate
asynkron-profiler --help,dotnet-trace --version, anddotnet-gcdump --versionall succeed- the chosen profiling mode matches the question being investigated
- the command profiles built
Releaseoutput unless there is a documented reason to acceptdotnet runnoise profile-output/contains the expected report or artifact after the run- any replay flow uses an input file type that matches the selected mode
References
- overview.md - tool positioning, install paths, prerequisites, and when to choose it over raw diagnostics CLIs
- commands.md - command patterns for capture, replay, and option tuning
- examples.md - mode-by-mode examples, output expectations, and troubleshooting checks
More from managedcode/dotnet-skills
dotnet
Primary router skill for broad .NET work. Classify the repo by app model and cross-cutting concern first, then switch to the narrowest matching .NET skill instead of staying at a generic layer.
18dotnet-aspnet-core
Build, debug, modernize, or review ASP.NET Core applications with correct hosting, middleware, security, configuration, logging, and deployment patterns on current .NET.
13dotnet-entity-framework-core
Design, tune, or review EF Core data access with proper modeling, migrations, query translation, performance, and lifetime management for modern .NET applications.
12dotnet-code-review
Review .NET changes for bugs, regressions, architectural drift, missing tests, incorrect async or disposal behavior, and platform-specific pitfalls before you approve or merge them.
11dotnet-architecture
Design or review .NET solution architecture across modular monoliths, clean architecture, vertical slices, microservices, DDD, CQRS, and cloud-native boundaries without over-engineering.
11dotnet-signalr
Implement or review SignalR hubs, streaming, reconnection, transport, and real-time delivery patterns in ASP.NET Core applications.
10