dtctl
Investigate incidents, debug performance issues, analyze logs, and manage observability resources in Dynatrace using the dtctl CLI. Use this skill whenever the user asks about error rates, latency spikes, service health, crash-looping pods, web vitals, SLO status, open problems, root cause analysis, log patterns, trace analysis, or building dashboards — even if they don't mention Dynatrace by name. Also covers DQL queries, workflow management, notebook and dashboard creation, settings configuration, and any operations against a Dynatrace environment.
What this skill does
# Dynatrace Control with dtctl Operate `dtctl`, the kubectl-style CLI for Dynatrace. This skill teaches core dtctl command patterns and operations. ## Recommended Initialization At the start of a task, run these checks to establish context and permissions: ```bash # Discover all available commands, flags, and resources dtctl commands --brief -o json # Show current context dtctl config current-context # Show context details dtctl config describe-context $(dtctl config current-context) --plain # Show authenticated user dtctl auth whoami --plain ``` This displays: - Current context name and environment URL - Safety level (readonly, readwrite-mine, readwrite-all, dangerously-unrestricted) - Authenticated user identity (name, email, UUID) ## DQL Reference Usage Before writing, modifying, or executing any DQL that fetches Dynatrace data (for example via `dtctl query`, `dtctl wait query`, or query files), you MUST consult `references/DQL-reference.md` and follow its documented syntax and templates. If there is any conflict between memory/assumptions and the reference, prefer the reference. ## Prerequisites If dtctl is not installed or not working, see [references/troubleshooting.md](references/troubleshooting.md) for installation and setup. ## Resources & Commands ### Available Resources dtctl uses a uniform pattern for all resource types. Discover schema from actual output with `dtctl describe <resource> <id> -o json --plain`. | Resource | Aliases | |----------|---------| | analyzer | analyzers | | app | apps | | aws connection | - | | aws monitoring | - | | azure connection | - | | azure monitoring | - | | bucket | bkt | | copilot-skill | copilot-skills | | dashboard | dash | | edgeconnect | ec | | extension | ext, extensions | | extension-config | extcfg, extension-configs | | function | fn, func | | gcp connection | - | | gcp monitoring | - | | group | groups | | intent | intents | | lookup | lookups, lkup | | notebook | nb | | notification | notifications | | sdk-version | sdk-versions | | settings | setting | | settings-schema | schema | | slo | - | | slo-template | slo-templates | | trash | deleted | | user | users | | workflow | wf | | workflow-execution | wfe | Use IDs whenever possible instead of names to avoid ambiguity. ### Command Verbs | Verb | Description | Example | |------|-------------|---------| | **get** | List resources | `dtctl get workflows --mine` | | **describe** | Show resource details | `dtctl describe workflow <id>` | | **edit** | Edit resource interactively | `dtctl edit dashboard <id>` | | **apply** | Create/update from file | `dtctl apply -f workflow.yaml --set env=prod` | | **delete** | Delete resource | `dtctl delete workflow <id>` | | **exec** | Execute workflow/function/analyzer/copilot | `dtctl exec workflow <id>` | | **query** | Run DQL query | `dtctl query "fetch logs \| limit 10"` | | **logs** | Print resource logs | `dtctl logs workflow-execution <id>` | | **wait** | Wait for conditions | `dtctl wait query "fetch logs" --for=any` | | **history** | Show document history | `dtctl history dashboard <id>` | | **restore** | Restore document version | `dtctl restore dashboard <id> --version 3` | | **share** | Share document | `dtctl share dashboard <id> --user [email protected]` | | **unshare** | Remove sharing | `dtctl unshare dashboard <id> --user [email protected]` | | **find** | Discover resources | `dtctl find intents --data trace.id=abc` | | **open** | Open in browser | `dtctl open intent <app/intent> --data key=value` | | **diff** | Compare resources | `dtctl diff -f workflow.yaml` | | **verify** | Validate without executing | `dtctl verify query 'fetch logs' --fail-on-warn` | | **commands** | List all commands (machine-readable) | `dtctl commands --brief -o json` | ## Key Concepts for AI Agents ### Output Modes ```bash # Agent envelope mode (auto-detected in AI environments) -A, --agent # Structured JSON envelope with ok/result/error/context --no-agent # Opt out of auto-detected agent mode # Machine-readable formats (use these for AI agents) -o json # JSON output -o yaml # YAML output -o csv # CSV output -o chart # ASCII chart (for time series) -o sparkline # ASCII sparkline (for time series) -o barchart # ASCII bar chart (for time series) # Human-readable formats -o table # Table format (default) -o wide # Wide table with more columns # Always use --plain flag for AI consumption (implied by --agent) --plain # Strips colors and prompts, best for parsing ``` **For AI agents, prefer:** `dtctl <command> --agent` (auto-detected) or `dtctl <command> -o json --plain` The `--agent` envelope provides structured metadata alongside results: ```json { "ok": true, "result": [ ... ], "context": { "verb": "get", "resource": "workflow", "total": 5, "has_more": false, "suggestions": ["Run 'dtctl describe workflow <id>' for details"] } } ``` ### Template Variables In YAML/DQL files, use Go template syntax: ```yaml # workflow.yaml title: "{{.environment}} Deployment" owner: "{{.team}}" trigger: schedule: cron: "{{.schedule | default "0 0 * * *"}}" ``` ```dql # query.dql fetch logs | filter host.name == "{{.host}}" | filter timestamp > now() - {{.timerange | default "1h"}} ``` Execute with: `dtctl apply -f file.yaml --set environment=prod --set team=platform` ### Copilot, Functions, Analyzers ```bash # Copilot skills dtctl get copilot-skills -o json --plain # Functions dtctl get functions -o json --plain dtctl exec function <id-or-name> --payload '{"key":"value"}' --plain # Analyzers dtctl get analyzers -o json --plain dtctl exec analyzer <id-or-name> --input '{"timeframe":"now-2h"}' --plain ``` Prefer `get ... -o json --plain` first, then `describe`/`exec` with explicit IDs. ### Authentication & Permissions ```bash # Check current user and permissions dtctl auth whoami --plain dtctl auth can-i create workflows dtctl auth can-i delete dashboards ``` Use `can-i` to verify permissions before attempting operations. ## Quick Reference: DQL Queries **Required workflow for DQL data fetching:** 1. First consult `references/DQL-reference.md` 2. Build/validate the query using the documented patterns 3. Execute with `dtctl query ... -o json --plain` (or `dtctl wait query ...` when waiting for results) ```bash # Inline query dtctl query "fetch logs | filter status='ERROR' | limit 100" -o json --plain # Query from file with variables dtctl query -f query.dql --set host=h-123 --set timerange=2h -o json --plain # Wait for query results dtctl wait query "fetch spans | filter test_id='test-123'" --for=count=1 --timeout 5m # Query with chart output dtctl query "timeseries avg(dt.host.cpu.usage)" -o chart --plain ``` ## Dashboards For full examples and field-level gotchas, see [references/resources/dashboards.md](references/resources/dashboards.md). Create/update: `dtctl apply -f dashboard.yaml --plain`. Export for reference: `dtctl get dashboard <id> -o yaml --plain`. ### YAML skeleton ```yaml name: "Dashboard Name" type: dashboard content: annotations: [] importedWithCode: false settings: defaultTimeframe: enabled: true value: { from: now()-2h, to: now() } layouts: "1": # string key, must match a tile key x: 0 # 24-column grid (full=24, half=12, third=8) "y": 0 # MUST quote "y" to avoid YAML boolean parse w: 12 h: 6 tiles: "1": title: "Tile Title" type: data # data | markdown query: | fetch logs | limit 10 visualization: lineChart visualizationSettings: autoSelectVisualization: false davis: { enabled: false, davisVisualization: { isAvailable: true } } ``` ### Tile types & visualizations - **`type: data`** — DQL tile with `query` + `visualization`: `singleValue`, `lineChart`, `areaChart`, `barChart`, `pieChart`, `table`
Related in Data & Analytics
clawarr-suite
IncludedComprehensive management for self-hosted media stacks (Sonarr, Radarr, Lidarr, Readarr, Prowlarr, Bazarr, Overseerr, Plex, Tautulli, SABnzbd, Recyclarr, Unpackerr, Notifiarr, Maintainerr, Kometa, FlareSolverr). Deep library exploration, analytics, dashboard generation, content management, request handling, subtitle management, indexer control, download monitoring, quality profile sync, library cleanup automation, notification routing, collection/overlay management, and media tracker integration (Trakt, Letterboxd, Simkl).
querying-soql
IncludedSOQL query generation, optimization, and analysis with 100-point scoring. Use this skill when the user needs SOQL/SOSL authoring or optimization: natural-language-to-query generation, relationship queries, aggregates, query-plan analysis, and performance or safety improvements for Salesforce queries. TRIGGER when: user writes, optimizes, or debugs SOQL/SOSL queries, touches .soql files, or asks about relationship queries, aggregates, or query performance. DO NOT TRIGGER when: bulk data operations (use handling-sf-data), Apex DML logic (use generating-apex), or report/dashboard queries.
app-store-optimization
IncludedApp Store Optimization (ASO) toolkit for researching keywords, analyzing competitor rankings, generating metadata suggestions, and improving app visibility on Apple App Store and Google Play Store. Use when the user asks about ASO, app store rankings, app metadata, app titles and descriptions, app store listings, app visibility, or mobile app marketing on iOS or Android. Supports keyword research and scoring, competitor keyword analysis, metadata optimization, A/B test planning, launch checklists, and tracking ranking changes.
habit-flow
IncludedAI-powered atomic habit tracker with natural language logging, streak tracking, smart reminders, and coaching. Use for creating habits, logging completions naturally ("I meditated today"), viewing progress, and getting personalized coaching.
app-store-optimization
IncludedApp Store Optimization (ASO) toolkit for researching keywords, analyzing competitor rankings, generating metadata suggestions, and improving app visibility on Apple App Store and Google Play Store. Use when the user asks about ASO, app store rankings, app metadata, app titles and descriptions, app store listings, app visibility, or mobile app marketing on iOS or Android. Supports keyword research and scoring, competitor keyword analysis, metadata optimization, A/B test planning, launch checklists, and tracking ranking changes.
visualizing-data
IncludedBuilds dashboards, reports, and data-driven interfaces requiring charts, graphs, or visual analytics. Provides systematic framework for selecting appropriate visualizations based on data characteristics and analytical purpose. Includes 24+ visualization types organized by purpose (trends, comparisons, distributions, relationships, flows, hierarchies, geospatial), accessibility patterns (WCAG 2.1 AA compliance), colorblind-safe palettes, and performance optimization strategies. Use when creating visualizations, choosing chart types, displaying data graphically, or designing data interfaces.