Back to MCP directory
publicPublicdnsLocal runtime

mcp-devcontainers

MCP Devcontainers是一个与devcontainers cli集成的MCP服务器,用于管理和操作开发容器。

article

README

🚀 mcp-devcontainers

MCP Devcontainers 是一个 Model Context Protocol (MCP) 服务器,它能与 devcontainers cli 进行简单集成,为开发提供便利。

🚀 快速开始

MCP 服务器会根据所使用的客户端进行不同配置。下面以 Claude Desktop 为例,展示其配置方式:

{
  "mcpServers": {
    "devcontainers": {
      "command": "npx",
      "args": [
        "-y",
        "@crunchloop/mcp-devcontainers"
      ]
    }
  }
}

✨ 主要特性

  • 简单集成:提供与 devcontainers cli 的简单集成。
  • 多工具支持:提供多种工具,可对 devcontainer 进行启动、运行脚本、执行命令等操作。

📦 安装指南

此服务器需要 Docker 已安装并正在系统上运行,因为它被 devcontainers cli 用于构建和管理开发容器。你可以参考以下安装指南进行安装:

没有其他依赖项可用于使用 MCP Devcontainers 服务器。

📚 详细文档

MCP 运输

目前,只实现了 stdio 运输。

工具

  • devcontainer_up:启动或初始化指定工作区文件夹中的 devcontainer 环境。使用此命令可确保 devcontainer 正在运行并准备好进行开发任务。

    • workspaceFolder:工作区文件夹路径(字符串,必需)
    • outputFilePath:写入输出日志的路径(字符串,可选)
  • devcontainer_run_user_commands:在指定工作区文件夹中的 devcontainer 中运行用户定义的 postCreateCommandpostStartCommand 脚本。使用此命令可在 devcontainer 启动后执行设置或初始化命令。

    • workspaceFolder:工作区文件夹路径(字符串,必需)
    • outputFilePath:写入输出日志的路径(字符串,可选)
  • devcontainer_exec:在指定工作区文件夹中的 devcontainer 中执行任意 shell 命令。使用此命令可在 devcontainer 上下文中运行自定义命令或脚本。

    • workspaceFolder:工作区文件夹路径(字符串,必需)
    • command:要执行的命令(字符串数组,必需)
    • outputFilePath:写入输出日志的路径(字符串,可选)

📄 许可证

本项目以 MIT License 发布。更多细节请参阅 LICENSE 文件。

help

Runtime guide

cloud

Hosted runtime

Hosted servers run from a provider-managed environment. You usually connect the MCP client to the hosted endpoint or follow the provider's authorization flow, without keeping a local process alive

  1. Open provider connection page
  2. Authorize or copy endpoint
  3. Connect from your MCP client
terminal

Local runtime / other methods

Local servers run on your own machine or infrastructure. You normally copy the server_config into your MCP client, install the required package, and provide env variables from env_schema when needed

  1. Copy server_config
  2. Install required package
  3. Fill env variables and restart client