devcontainer
3
总安装量
3
周安装量
#56448
全站排名
安装命令
npx skills add https://github.com/tyler-r-kendrick/agent-skills --skill devcontainer
Agent 安装分布
amp
3
gemini-cli
3
github-copilot
3
codex
3
kimi-cli
3
opencode
3
Skill 文档
Dev Containers
Overview
Dev containers define reproducible development environments using a devcontainer.json file. They are the foundation of GitHub Codespaces and work with VS Code Dev Containers, the devcontainer CLI, and DevPod.
File Location
Place devcontainer.json in one of:
.devcontainer/devcontainer.json(preferred).devcontainer.json(repo root).devcontainer/<folder>/devcontainer.json(multiple configs)
Minimal Configuration
{
"name": "My Project",
"image": "mcr.microsoft.com/devcontainers/base:ubuntu",
"forwardPorts": [3000],
"postCreateCommand": "npm install"
}
Base Image Options
| Image | Use Case |
|---|---|
mcr.microsoft.com/devcontainers/base:ubuntu |
General-purpose |
mcr.microsoft.com/devcontainers/javascript-node:22 |
Node.js / TypeScript |
mcr.microsoft.com/devcontainers/python:3.12 |
Python |
mcr.microsoft.com/devcontainers/dotnet:9.0 |
.NET |
mcr.microsoft.com/devcontainers/universal:2 |
Multi-language (Codespaces default) |
Features
Features install additional tools without custom Dockerfiles:
{
"features": {
"ghcr.io/devcontainers/features/docker-in-docker:2": {},
"ghcr.io/devcontainers/features/node:1": { "version": "22" },
"ghcr.io/devcontainers/features/python:1": { "version": "3.12" },
"ghcr.io/devcontainers/features/go:1": { "version": "1.24" },
"ghcr.io/devcontainers/features/github-cli:1": {}
}
}
Lifecycle Hooks
Hooks run at different stages. Each can be a string, array, or object (parallel commands):
{
// Runs on host before container creation
"initializeCommand": "echo 'Starting build'",
// Runs once after container is created
"onCreateCommand": {
"deps": "npm ci",
"db": "npm run db:setup"
},
// Runs when new content is available (rebuild / prebuilt update)
"updateContentCommand": "npm install",
// Runs after onCreateCommand and updateContentCommand complete
"postCreateCommand": "npm run build",
// Runs every time the container starts
"postStartCommand": {
"server": "npm run dev",
"watch": "npm run watch"
},
// Runs every time an editor attaches
"postAttachCommand": "echo 'Ready'",
// Which command to wait for before showing as ready
"waitFor": "postCreateCommand"
}
Port Forwarding
{
"forwardPorts": [3000, 5432, 6379],
"portsAttributes": {
"3000": {
"label": "Application",
"onAutoForward": "openBrowser"
},
"5432": {
"label": "Database",
"onAutoForward": "silent"
}
}
}
Environment Variables
{
// Available in all processes inside the container
"containerEnv": {
"MY_VAR": "value"
},
// Available only in the integrated terminal / remote connection
"remoteEnv": {
"DATABASE_URL": "postgresql://user:pass@db:5432/mydb"
},
// User-level environment
"remoteUser": "vscode"
}
VS Code Customizations
{
"customizations": {
"vscode": {
"extensions": [
"dbaeumer.vscode-eslint",
"esbenp.prettier-vscode",
"ms-dotnettools.csdevkit"
],
"settings": {
"editor.formatOnSave": true,
"editor.defaultFormatter": "esbenp.prettier-vscode"
}
}
}
}
Using a Dockerfile
{
"build": {
"dockerfile": "Dockerfile",
"context": "..",
"args": {
"VARIANT": "22-bookworm"
}
}
}
Best Practices
- Prefer features over custom Dockerfiles for common tools â they compose well and cache independently.
- Use
postCreateCommandfor project-specific setup (dependency install, migrations) andpostStartCommandfor starting dev servers. - Pin feature versions with major version tags (e.g.,
:2) rather than:latest. - Use
containerEnvfor build-time variables andremoteEnvfor secrets or connection strings. - Enable Codespaces prebuilds to cache
postCreateCommandresults and speed up start times. - Use
"shutdownAction": "stopCompose"with Docker Compose setups to clean up sidecar containers. - Keep
.devcontainer/in version control so every contributor gets the same environment.