Provides expert guidance on Development Containers (devcontainers) — creating, configuring, and optimising containerised development environments using the Dev Container Specification. This skill should be used when users ask about devcontainer.json, .devcontainer setup, Dev Container Features or Templates, pre-building images, multi-container workflows, Docker-in-Docker, cloud development environments (Codespaces, DevPod), or troubleshooting container performance and permission issues.
Resources
1Install
npx skillscat add markpitt/claude-skills/devcontainers Install via the SkillsCat registry.
Dev Containers Skill
Expert guidance on creating, configuring, and optimising containerised development environments using the Dev Container Specification. Covers devcontainer.json authoring, Features, Templates, performance, security, multi-container setups, and cloud environments.
Quick Reference Table
| Task | Load Resource | Key Concepts |
|---|---|---|
Create or configure a devcontainer.json |
references/core-concepts.md |
image, build, features, lifecycle hooks, customizations |
| Add tools/languages to a container | references/features-templates.md |
Features, version pinning, installsAfter, Templates |
| Set up multi-container or Docker-in-Docker | references/advanced-config.md |
dockerComposeFile, DinD, DooD, Kubernetes, service |
| Improve build/startup speed | references/performance-security.md |
layer caching, named volumes, pre-built images, Virtio-fs |
| Harden container security or manage secrets | references/performance-security.md |
remoteUser, UID mapping, SSH forwarding, secrets |
| Debug slow mounts, permission errors, credential issues | references/troubleshooting.md |
UID/GID, bind mounts, SSH agent, postCreateCommand |
| Integrate with Codespaces or DevPod | references/advanced-config.md |
prebuilds, providers, SSH, cloud residency |
Orchestration Protocol
Phase 1 — Classify the Task
Identify which category the user's request falls into:
- Configuration — writing or editing
devcontainer.json, Dockerfiles, Compose files - Tooling — adding Features, authoring custom Features, or using Templates
- Advanced — multi-container, DinD/DooD, Kubernetes, cloud environments
- Optimisation — caching, pre-built images, named volumes, disk I/O
- Security — non-root users, UID mapping, secrets, hardened images
- Troubleshooting — permission errors, slow builds, SSH/GPG credential issues
Phase 2 — Load the Right Resource
Load the resource indicated in the Quick Reference Table. For complex tasks spanning multiple areas (e.g. "set up a secure multi-container environment with fast builds"), load both relevant files.
Phase 3 — Execute
Apply the guidance from the loaded resource. Use concrete examples from the resource files. For configuration tasks, produce a complete, commented devcontainer.json snippet.
Common Task Workflows
Workflow 1: Create a New Dev Container from Scratch
- Load
references/core-concepts.mdfor the full property reference - Choose orchestration method:
image(simplest),build.dockerfile, ordockerComposeFile - Add
featuresfor tools (Node.js, Python, Git, Docker CLI, etc.) - Set
remoteUserto a non-root user for security - Add
customizations.vscode.extensionsandsettingsfor IDE consistency - Add
postCreateCommandto install dependencies automatically - Add
forwardPortsfor any app ports
{
"name": "My Project",
"image": "mcr.microsoft.com/devcontainers/base:ubuntu",
"features": {
"ghcr.io/devcontainers/features/node:1": { "version": "20" },
"ghcr.io/devcontainers/features/git:1": {}
},
"customizations": {
"vscode": {
"extensions": ["dbaeumer.vscode-eslint", "esbenp.prettier-vscode"],
"settings": { "editor.formatOnSave": true }
}
},
"postCreateCommand": "npm install",
"forwardPorts": [3000],
"remoteUser": "node"
}Workflow 2: Add a Tool via Features
- Load
references/features-templates.md - Browse the official registry or GitHub Container Registry
- Add the feature with a pinned version to
devcontainer.json - Use
overrideFeatureInstallOrderif ordering matters
Workflow 3: Multi-Container Setup with Docker Compose
- Load
references/advanced-config.md - Create
docker-compose.ymlfor services (app, database, cache) - Create
docker-compose.dev.ymlfor development overrides (source mounts, debug ports) - Set
dockerComposeFileto both files indevcontainer.json - Set
serviceto the container the IDE should attach to - Set
shutdownAction: "none"to keep services running when IDE closes
Workflow 4: Speed Up Dev Container Builds
- Load
references/performance-security.md - Order Dockerfile instructions from least-changed to most-changed
- Use
RUN --mount=type=cachefor package managers - Use named volumes for
node_modules/ heavy dependency directories - Pre-build and push image in CI; reference the pre-built image in
devcontainer.json
Workflow 5: Troubleshoot a Permission or Credential Issue
- Load
references/troubleshooting.md - For UID mismatch: ensure
updateRemoteUserUID: true(default on Linux) - For SSH: ensure local SSH agent is running; the extension auto-forwards it
- For Git inside container: use SSH agent forwarding; do not copy private keys
Resource Summaries
| File | Contents | Lines |
|---|---|---|
references/core-concepts.md |
Full devcontainer.json property reference, lifecycle hooks, location precedence |
~280 |
references/features-templates.md |
Consuming and authoring Features, Templates distribution, version pinning | ~260 |
references/advanced-config.md |
Multi-container, Docker-in-Docker/from-Docker, Kubernetes, Codespaces, DevPod | ~280 |
references/performance-security.md |
Layer caching, named volumes, pre-built images, non-root users, secrets | ~270 |
references/troubleshooting.md |
Permission errors, slow I/O, SSH/GPG credentials, lifecycle script issues | ~200 |
Best Practices
- Version-pin everything — pin Features (
feature:1) and base images (python:3.12) for reproducibility - Non-root by default — always set
remoteUserto a non-root user; useupdateRemoteUserUID: trueon Linux - Automate setup — use
postCreateCommandto install dependencies so the environment is immediately usable - Don't modify production Compose — use a
docker-compose.dev.ymloverride for dev-specific additions - Pre-build images in CI — reduces startup from minutes to seconds; embed metadata in image labels
- Never bake secrets into images — use SSH agent forwarding, BuildKit secret mounts, or
.envfiles (git-ignored) - Named volumes for heavy directories — on macOS/Windows, mount
node_modulesetc. into named volumes for native I/O speed
External References
- Dev Container Specification — official specification and schema
- devcontainer.json reference — full property reference
- Official Features registry — browse available Features
- Official Templates registry — browse available Templates
- VS Code Dev Containers docs — IDE integration guide
- GitHub Codespaces docs — cloud-hosted containers
- DevPod docs — open-source provider-agnostic cloud dev environments
- devcontainers/cli — reference CLI implementation