askill
app-platform-troubleshooting

app-platform-troubleshootingSafety 90Repository

Debug running App Platform applications by accessing containers, analyzing logs, running diagnostics, and applying fixes. Use when apps fail to deploy, crash at runtime, have connectivity issues, or need performance diagnosis.

1 stars
1.2k downloads
Updated 2/8/2026

Package Files

Loading files...
SKILL.md

App Platform Troubleshooting Skill

Transform debugging from guessing to rapid diagnosis and fix.

Philosophy

Traditional: See error → Guess → Change → Push → Wait 5-7 min → Repeat
With skill:  See error → Diagnose → Fix → Verify → Commit proper fix

Quick Decision

Is the app deployed with running containers?
├── YES → Can we access the shell?
│         ├── YES → LIVE MODE (SDK shell access)
│         └── NO  → LOGS-ONLY MODE (fetch logs)
└── NO (build/deploy failed) → LOGS-ONLY MODE

Mode 1: Live Troubleshooting (Quick Start)

from do_app_sandbox import Sandbox

app = Sandbox.get_from_id(app_id="<app-id>", component="web")

# Diagnostics
app.exec("env | grep DATABASE")
app.exec("curl -v localhost:8080/health")
app.exec("ps aux | head -10")

Full guide: See live-troubleshooting.md


Mode 2: Logs-Only (Quick Start)

# Runtime logs
doctl apps logs <app_id> <component> --type run

# Build logs
doctl apps logs <app_id> <component> --type build

# Crash logs
doctl apps logs <app_id> --type=run_restarted

Full guide: See logs-analysis.md


Debug Container (Infrastructure Issues)

Deploy in ~30-45 seconds to isolate infrastructure from application:

services:
  - name: debug
    image:
      registry_type: GHCR
      registry: ghcr.io
      repository: bikramkgupta/debug-python
      tag: latest
    http_port: 8080
    envs:
      - key: DATABASE_URL
        value: ${db.DATABASE_URL}
# Run validation suite
validate-infra all
validate-infra database
validate-infra kafka

Full guide: See debug-container.md


Quick Reference: Exit Codes

CodeSignalMeaning
0-Clean exit (shouldn't exit)
1-General error
127-Command not found
137SIGKILLOOM killed
143SIGTERMGraceful shutdown

Quick Reference: Common Fixes

ProblemQuick Fix
App exits immediatelyCheck if listening on $PORT
502 errorsCheck health endpoint, verify running
Database connection failsUse Debug Container, verify trusted sources
Build failsCheck dependencies, review build logs
OOM killsUpgrade instance size
Health checks failBind to 0.0.0.0, not localhost
Slow startupIncrease initial_delay_seconds

Reference Files


When to Escalate

Contact DigitalOcean Support when:

  • Internal error persists after redeploy
  • Resource limit increases needed
  • Multiple apps affected (platform issue)
  • VPC/networking issues can't be diagnosed

Before escalating, gather:

doctl apps get <app_id> -o json > app_info.json
doctl apps logs <app_id> <component> --type run > runtime.log
doctl apps spec get <app_id> > app_spec.yaml

Integration with Other Skills

  • → deployment: After fixing, deploy proper changes
  • → devcontainers: Reproduce issues locally
  • → postgres: Database-specific configuration
  • → networking: Comprehensive networking docs

Install

Download ZIP
Requires askill CLI v1.0+

AI Quality Score

95/100Analyzed 2/13/2026

A comprehensive troubleshooting guide for DigitalOcean App Platform, featuring decision trees, specific CLI/SDK commands for live and log-based debugging, and reference tables for exit codes and common fixes. It effectively bridges high-level diagnosis strategies with low-level execution steps.

90
95
90
95
95

Metadata

Licenseunknown
Version1.0.0
Updated2/8/2026
Publisherdigitalocean-labs

Tags

ci-cddatabasegithub-actions