返回 Skill 列表
extension
分类: 开发与工程无需 API Key

devcontainers-best-practices

查找开发容器规范、devcontainer.json参考和架构;找到功能和模板;识别支持开发容器的工具(如VS Code、基于VS Code的编辑器如Cursor、Zed、Codespaces、DevPod等)。在编辑devcontainer.json、选择功能或模板时,或者当用户询问关于开发容器、devcontainer.json或containers.dev时使用。

person作者: jakexiaohubgithub

Devcontainers Best Practices

This skill guides you to the right documentation and references for the Development Container ecosystem. Use it when working with devcontainer.json, selecting Features or Templates, or when the user asks about dev containers, containers.dev, or supporting tools.

Quick start

Minimal devcontainer.json using an image and a Feature: "image": "mcr.microsoft.com/devcontainers/base:ubuntu", "features": { "ghcr.io/devcontainers/features/git:1": {} }. For property details and validation, see Quick lookup item 1 and references/schema.md.

When to use this skill

  • Editing or validating devcontainer.json
  • Looking up a property (syntax, type, tool support)
  • Choosing or referencing a Feature or Template
  • Checking which tools support the spec or have tool-specific properties/limitations
  • Understanding the spec (lifecycle, merge logic, image metadata)
  • Authoring or publishing a Dev Container Feature (see the Authoring section in references/features.md and the containers.dev authoring guide)
  • Configuring multiple dev containers (multi-project, shared Compose); see references/tools.md and VS Code / multi-container docs

Canonical sources

All content in this skill and its references is traceable to these sources:

Reference files

Detailed material is in the references/ directory. Load only what you need.

| Need | File | |------|------| | When to use the full spec, key concepts, merge logic, lifecycle | references/spec.md | | JSON reference vs schema, canonical URLs, how to validate | references/schema.md | | Supporting tools, tool-specific properties, limitations | references/tools.md | | VS Code workflows, requirements, prebuild, ports, extensions, limitations, dotfiles, managing containers | references/vscode-containers.md | | Tips and tricks (OS, Git, performance, troubleshooting, profile persistence, reporting) | references/tips-and-tricks.md | | Official Features, OCI refs, versioning, options, install order, authoring Features | references/features.md | | Official Templates, when to use template vs Feature vs Dockerfile | references/templates.md |

Quick lookup

  1. Property or behavior in devcontainer.json
    Use the Dev Container metadata reference (or references/spec.md) for property-by-property details. For validation, use the devcontainer.json schema or Dev Container CLI; see references/schema.md.

  2. Tool support or tool-specific settings
    Check devcontainers.github.io/supporting for the list of tools, customizations.* (e.g. customizations.vscode, customizations.codespaces), and limitations. Summary in references/tools.md.

  3. Advanced scenarios (env vars, mounts, performance, non-root user, remote Docker, multiple containers, Git credentials)
    See VS Code Advanced container configuration. Summary and workflow links in references/vscode-containers.md.

  4. Multiple dev containers (multi-project, shared Docker Compose)
    See references/tools.md “Multiple containers / multi-project” and Chris Ayers – Multiple dev containers.

  5. OS-specific or troubleshooting (Git, Docker Desktop, cleanup, logs)
    See VS Code Dev Containers Tips and Tricks. Summary in references/tips-and-tricks.md.

  6. Feature ID, options, or install order
    Official Features: containers.dev/features, github.com/devcontainers/features. OCI refs: ghcr.io/devcontainers/features/<name>:<version>. Details in references/features.md. For authoring Features, see the Authoring section there and containers.dev/guide/feature-authoring-best-practices.

  7. Template or "template vs Feature vs Dockerfile"
    Official Templates: containers.dev/templates, github.com/devcontainers/templates. When to use which: references/templates.md.

  8. Spec concepts (lifecycle, merge, image metadata)
    Full spec: containers.dev/implementors/spec. Summary: references/spec.md.

Best practices (from official docs)

Only apply recommendations that are stated in the spec or official devcontainer documentation; cite the source when relevant.

When the spec or official docs do not state a recommendation, do not present it as a best practice; either omit it or phrase it as a suggestion with a clear citation.

Optional / community guidance: Community articles (e.g. Daytona – Ultimate guide to dev containers) suggest practices such as keeping images lightweight, caching dependencies, and using Docker Compose for multi-service setups. Use with attribution and prefer spec/official docs when they conflict.

Summary

  • Use this skill when editing devcontainer.json, choosing Features/Templates, authoring Features, or answering questions about dev containers or containers.dev.
  • Resolve questions via the canonical URLs above and the reference files under references/.
  • Best practices: cite containers.dev or devcontainers.github.io; only include guidance that appears there. For OS-specific or troubleshooting issues, consult VS Code Dev Containers Tips and Tricks and references/tips-and-tricks.md.