
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
本镜像是一个集成了 VSCode 服务与数据科学专用 Python 环境的 Docker 镜像。它基于 Python 环境构建,预装了数据科学领域常用的开发工具、库和依赖,旨在为数据科学家、机器学习工程师及分析师提供开箱即用的统一开发环境。通过容器化部署,实现开发环境的快速搭建、环境隔离与跨平台可移植性,简化数据科学项目的开发、调试与协作流程。
假设镜像托管于 Docker Hub,通过以下命令拉取(实际使用时替换 <镜像名称> 为具体镜像标签):
bashdocker pull <镜像名称>:latest # 拉取最新版本 # 或指定版本:docker pull <镜像名称>:python3.9-tensorflow2.10
通过 docker run 启动容器,基本命令格式如下:
bashdocker run -d \ -p <宿主机端口>:8080 \ # 端口映射(容器内默认端口 8080) -v <宿主机目录>:/workspace \ # 挂载工作目录(持久化代码和数据) -e PASSWORD=<访问密码> \ # 设置访问密码(可选,建议设置) --name <容器名称> \ # 自定义容器名称 <镜像名称>:latest
示例:启动一个端口映射到宿主机 8888,工作目录挂载当前目录 ./workspace,密码为 datascience123 的容器:
bashdocker run -d \ -p 8888:8080 \ -v $(pwd)/workspace:/workspace \ -e PASSWORD=datascience123 \ --name vscode-ds-env \ vscode-datascience-python:latest
容器启动后,通过浏览器访问以下地址:
http://<宿主机IP>:<宿主机端口> # 如 localhost:8888
首次访问时输入设置的 PASSWORD(若未设置密码,可能直接进入),即可进入 VSCode Web 界面。
通过 -e 参数设置环境变量,自定义容器行为。支持的环境变量如下:
| 环境变量名 | 用途描述 | 默认值 | 是否必填 |
|---|---|---|---|
PASSWORD | 访问 VSCode 服务的密码 | 无 | 否 |
PORT | 容器内 VSCode 服务端口 | 8080 | 否 |
PYTHON_VERSION | 指定 Python 版本(需镜像支持) | 3.10 | 否 |
EXTRA_PACKAGES | 启动时额外安装的 Python 包 | 无 | 否 |
ENABLE_JUPYTER | 是否启用 Jupyter Notebook 集成 | true | 否 |
示例:指定端口 9000,安装 statsmodels 和 pymc3 包:
bashdocker run -d \ -p 9000:9000 \ -e PORT=9000 \ -e EXTRA_PACKAGES="statsmodels pymc3" \ vscode-datascience-python:latest
对于复杂场景(如挂载多个目录、集成其他服务),可使用 docker-compose.yml 管理容器:
yamlversion: '3.8' services: vscode-ds: image: vscode-datascience-python:latest container_name: vscode-ds-env ports: - "8888:8080" # 宿主机端口:容器端口 volumes: - ./workspace:/workspace # 代码和数据目录 - ./vscode-settings:/root/.vscode # 持久化 VSCode 设置 - ./conda-envs:/root/miniconda3/envs # 持久化 Python 虚拟环境 environment: - PASSWORD=datascience123 - PYTHON_VERSION=3.9 - EXTRA_PACKAGES="torch torchvision scikit-image" restart: unless-stopped # 容器退出时自动重启(除非手动停止)
启动命令:
bashdocker-compose up -d # 后台启动服务 docker-compose logs -f # 查看实时日志 docker-compose down # 停止并删除服务
为避免容器删除后数据丢失,需通过 -v 参数挂载以下目录:
/workspace(存放代码、数据文件,建议必挂载)/root/.vscode(保存扩展、用户配置,可选)/root/miniconda3/envs(若使用 conda 虚拟环境,可选)示例(完整挂载):
bashdocker run -d \ -p 8888:8080 \ -v $(pwd)/workspace:/workspace \ -v $(pwd)/vscode-config:/root/.vscode \ -v $(pwd)/python-envs:/root/miniconda3/envs \ -e PASSWORD=mysecret \ vscode-datascience-python:latest
4.7.1 安装额外 Python 包
docker exec -it <容器名> /bin/bash),直接使用 pip install <包名> 或 conda install <包名>EXTRA_PACKAGES 环境变量指定(见 4.4 节),或在工作目录中创建 requirements.txt,通过终端执行 pip install -r requirements.txt4.7.2 修改 VSCode 配置
通过 VSCode Web 界面的 文件 > 首选项 > 设置 进行配置,或直接编辑挂载的 vscode-settings 目录下的 settings.json 文件。
| 参数/环境变量 | 类型 | 说明 | 默认值 | 示例值 |
|---|---|---|---|---|
PORT | 环境变量 | 容器内 VSCode 服务监听端口 | 8080 | 9000 |
PASSWORD | 环境变量 | 访问 VSCode 服务的密码(长度建议 ≥6 位) | 空(无密码) | mysecret123 |
PYTHON_VERSION | 环境变量 | 指定 Python 版本(需镜像支持,如 3.8/3.9/3.10) | 3.10 | 3.9 |
EXTRA_PACKAGES | 环境变量 | 启动时额外安装的 Python 包,多个包用空格分隔 | 空 | "pandas==1.5.3 torch==2.0.0" |
ENABLE_JUPYTER | 环境变量 | 是否启用 Jupyter Notebook 集成(true/false) | true | false |
-p <host>:<container> | 启动参数 | 端口映射,宿主机端口:容器端口(容器端口需与 PORT 一致) | - | -p 8888:8080 |
-v <host>:<container> | 启动参数 | 卷挂载,宿主机目录:容器内目录(常用目录:/workspace、/root/.vscode) | - | -v $(pwd)/data:/workspace/data |
netstat -tuln | grep <端口>),或容器是否正常运行(docker ps)。chmod -R 777 <目录>(仅测试环境,生产环境需配置正确用户权限)。--gpus all(如 docker run --gpus all ...)。docker pull <镜像名称>:latest 获取最新版本,旧容器需删除后重新创建。您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。






来自真实用户的反馈,见证轩辕镜像的优质服务