Windows 上通过 VScode 配置 Docker

Windows 上通过 VScode 配置Docker

引言

在现代软件开发中,容器化技术已经成为确保开发环境一致性的重要手段。本文将详细介绍如何使用 VS Code 的 Dev Containers 扩展来在 Unstructured 容器环境中开发本地项目,从问题的提出到最终解决方案的实施,包括所有必要的步骤和配置。

前提

电脑已经安装好 Docker。

可以看我另一篇文章:
Windows 11 下正确安装 Docker Desktop 到 D 盘的完整教程

问题背景

本教程使用开源项目 unstructured 的 Docker 部署为例子。

在使用 Unstructured 这样的专业工具进行开发时,我们常常需要特定的运行环境。虽然可以通过 Docker 容器获得这个环境,但如何在容器中访问和开发本地项目文件成为一个常见挑战。

解决方案:使用 Dev-Containers 扩展

步骤 1:安装必要的扩展

首先,确保安装了 VS Code 的 Dev Containers 扩展:

  1. 打开 VS Code
  2. 点击左侧扩展图标或按 Ctrl+Shift+X
  3. 搜索 "Dev Containers"
  4. 安装 Microsoft 官方的 "Dev Containers" 扩展

步骤 2:创建 devcontainer.json 配置

在本地项目目录中创建必要的配置文件:

  1. 在项目根目录创建 .devcontainer 文件夹
  2. 在该文件夹中创建 devcontainer.json 文件
  3. 添加以下配置内容:
json 复制代码
{
  "name": "Unstructured Project",
  "image": "downloads.unstructured.io/unstructured-io/unstructured:latest",
  "workspaceMount": "source=${localWorkspaceFolder},target=/workspace,type=bind,consistency=cached",
  "workspaceFolder": "/workspace",
  "customizations": {
    "vscode": {
      "extensions": [
        "ms-python.python",
        "ms-python.vscode-pylance"
      ]
    }
  }
}

这个配置文件指定了:

  • 使用 Unstructured 的官方 Docker 镜像
  • 将本地项目目录挂载到容器的 /workspace 路径
  • 自动安装 Python 相关的 VS Code 扩展

步骤 3:在容器中重新打开项目

配置完成后:

  1. 在 VS Code 中打开命令面板(Ctrl+Shift+P
  2. 输入并选择 "Dev Containers: Reopen in Container"
  3. VS Code 将自动:
    • 基于指定的镜像创建一个新容器
    • 挂载本地项目目录到容器中
    • 在容器环境中重新打开 VS Code 窗口

步骤 4:验证结果

成功实施后,我们可以看到:

  1. Docker Desktop 显示一个新的容器已启动(如截图所示,名为 "clever_faraday")
  2. 容器使用的是 Unstructured 镜像
  3. VS Code 窗口现在连接到了容器环境
  4. 在 VS Code 的文件浏览器中可以看到并编辑本地项目文件
  5. 所有操作都在 Unstructured 的环境中执行,同时保持对本地文件的访问

    配置好后,最后别忘了安装项目:
bash 复制代码
pip install "unstructured[all-docs]"

工作原理解析

Dev Containers 扩展的核心功能是将本地开发与容器化环境无缝集成:

  1. 挂载机制 :通过 workspaceMount 配置,实现本地文件系统与容器内部文件系统的双向同步
  2. 环境隔离:代码在容器内运行,确保环境一致性,避免"在我的机器上可以运行"的问题
  3. 开发体验保持:VS Code 的所有功能(代码补全、调试等)在容器环境中依然可用

常见问题排查

如果遇到问题:

  1. 容器无法启动:检查 Docker Desktop 是否正在运行,以及镜像是否已经安装
  2. 文件更改不同步 :确认 workspaceMount 配置正确,并检查文件权限

最后

这种方法不仅适用于 Unstructured,也可以扩展到其他需要特定环境的项目开发中。


相关推荐
@Dai2 小时前
【AI】DeepSeek本地部署,Ollama + vscode + Continue,实现本地运行LLM大模型,以及代码自动补全
人工智能·vscode·深度学习·学习·编辑器
盖盖衍上3 小时前
Java 8 新特性
java·windows·python
encoding-console4 小时前
Centos7部署k8s(单master节点安装)
docker·云原生·容器·kubernetes·部署·集群·centos7
大丈夫在世当日食一鲲4 小时前
Java的流表达式使用
java·开发语言·windows
扛枪的书生5 小时前
Windows 提权-不安全的 GUI 程序
windows·渗透·kali·提权
reddingtons5 小时前
在 Ubuntu 下通过 Docker 部署 Caddy 和 PHP-FPM 服务器
服务器·ubuntu·docker
酥暮沐6 小时前
Docker 学习(一)
运维·docker·容器
匹马夕阳7 小时前
在VSCode 中使用通义灵码最新版详细教程
ide·vscode·编辑器
sqmeeting7 小时前
QT6开发高性能企业视频会议-8 使用VSCode+Copilot AI开发
人工智能·vscode·copilot
暴躁的小胡!!!8 小时前
Windows权限维持之不死马(一)
运维·服务器·网络·windows·安全