
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
https://hub.docker.com/r/stainless403/mdcx-builtin-gui-base%EF%BC%8C%E6%98%AF%E5%9F%BA%E4%BA%8E https://hub.docker.com/r/jlesage/baseimage-gui 构建的适合python+QT5应用运行的镜像。
优点是
轻量,缺点是只支持通过网页查看,且没有文件管理。
复制以下命令到终端运行,第一步选择模版 1) mdcx-builtin-gui-base ,然后根据提示输入几个参数即可完成部署。
使用curl:
bashbash -c "$(curl -fsSL https://raw.githubusercontent.com/northsea4/mdcx-docker/main/install.sh)"
使用wget:
bashbash -c "$(wget https://raw.githubusercontent.com/northsea4/mdcx-docker/main/install.sh -O -)"
以下的步骤是手动部署的详细说明,即使使用了脚本部署,也请务必阅读一下了解更多细节,如安全、更新等。
https://hub.docker.com/r/stainless403/mdcx-builtin-gui-base%E9%95%9C%E5%83%8F%E5%B7%B2%E5%86%85%E7%BD%AE%E7%BC%96%E8%AF%91%E5%A5%BD%E7%9A%84MDCx%EF%BC%8C%E7%9B%B4%E6%8E%A5%E9%83%A8%E7%BD%B2%E5%8D%B3%E5%8F%AF%E4%BD%BF%E7%94%A8%E3%80%82
下载 https://github.com/northsea4/mdcx-docker/releases/download/latest/template-mdcx-builtin-gui-base.zip%EF%BC%8C%E8%A7%A3%E5%8E%8B%E5%88%B0%E5%90%88%E9%80%82%E7%9A%84%E4%BD%8D%E7%BD%AE%E5%90%8E%EF%BC%8C%E8%BF%9B%E5%85%A5%E9%A1%B9%E7%9B%AE%E7%9B%AE%E5%BD%95%E3%80%82%E5%A6%82%E6%97%A0%E7%89%B9%E5%88%AB%E8%AF%B4%E6%98%8E%EF%BC%8C%E4%B9%8B%E5%90%8E%E7%9A%84%E6%93%8D%E4%BD%9C%E9%83%BD%E6%98%AF%E5%9C%A8%E8%AF%A5%E7%9B%AE%E5%BD%95(%E5%81%87%E8%AE%BE%E5%90%8D%E4%B8%BA%60mdcx-docker%60)%E5%86%85%E8%BF%9B%E8%A1%8C%E3%80%82
整个项目的结构大致如下:
mdcx-docker |-- data ------容器系统数据 ... |-- mdcx-config --------应用配置文件目录 |-- config.v2.json |-- MDCx.config |-- logs --------应用日志目录 |-- 2023-02-04-01-15-00.txt |-- .env ------环境变量文件 |-- .env.sample ------环境变量示例文件 |-- .env.versions ------应用版本文件 |-- gui-base-builtin.sample.yml -------容器部署配置示例 |-- docker-compose.yml -------容器部署配置
编辑.env文件,按需修改。
文件里每个参数都有具体的说明,.env.sample文件里可以查看原始的数值。
一般需要修改的参数:VNC_PASSWORD, WEB_PORT, VNC_PORT, USER_ID, GROUP_ID
| 参数名称 | 说明 | 默认值 | 必填 |
|---|---|---|---|
| VNC_PASSWORD | 访问密码,如不需要,留空。如果有在公网远程访问的需求,建议设置 | 无 | 否 |
| WEB_PORT | 网页访问端口 | 5800 | 是 |
| VNC_PORT | VNC监听端口 | 5900 | 是 |
| USER_ID | 运行应用的用户ID,通过id -u命令可以查看当前用户ID,id -u user1则可以查看用户user1的用户ID | 0 | 是 |
| GROUP_ID | 运行应用的用户组ID,通过id -g命令可以查看当前用户组ID,id -g user1则可以查看用户user1的用户组ID | 0 | 是 |
| DISPLAY_WIDTH | 应用窗口宽度 | 1200 | 否 |
| DISPLAY_HEIGHT | 应用窗口高度 | 750 | 否 |
ymlversion: '3' services: mdcx: image: stainless403/mdcx-builtin-gui-base:${MDCX_BUILTIN_IMAGE_TAG} container_name: ${MDCX_CONTAINER_NAME} env_file: - .env volumes: # 系统数据目录 - ./data:/config # 配置文件目录 - ./mdcx-config:/mdcx-config # `配置文件目录`标记文件(纯文本文件,内容为当前使用的配置文件路径,默认/mdcx-config/config.v2.json) - ./mdcx-config/MDCx.config:/app/MDCx.config # 日志目录 - ./logs:/app/Log # 影片目录 - /path/to/movies:/movies ports: - ${WEB_PORT}:5800 - ${VNC_PORT}:5900 restart: unless-stopped network_mode: bridge stdin_open: true
bashdocker-compose up -d # 查看容器日志,容器名称请根据实际情况修改 # docker logs -f mdcx_gui # 或者 # docker-compose logs -f
假设服务器IP为192.168.1.100,使用默认端口5800,则访问地址为:[***]
/path/to/ 替换为你实际的路径。
bash# 选一个合适的目录 MDCX_DOCKER_DIR=/path/to/mdcx-docker mkdir -p $MDCX_DOCKER_DIR && cd $MDCX_DOCKER_DIR # 必须:相关数据或日志目录 mkdir -p mdcx-config logs data # 必须:配置文件目录标记文件 echo "/mdcx-config/config.v2.json" > mdcx-config/MDCx.config # 不需要手动创建配置文件,程序会自动创建 docker run -d --name mdcx \ -p 5800:5800 `#Web访问端口` \ -p 5900:5900 \ -v $(pwd)/data:/config `#容器系统数据` \ -v $(pwd)/mdcx-config:/mdcx-config `#配置文件目录` \ -v $(pwd)/mdcx-config/MDCx.config:/app/MDCx.config `#配置文件目录标记文件` \ -v $(pwd)/logs:/app/Log `#日志目录` \ -v /volume2:/volume2 `#影片目录` \ -e TZ=Asia/Shanghai \ -e DISPLAY_WIDTH=1200 \ -e DISPLAY_HEIGHT=750 \ -e VNC_PASSWORD= `#查看密码` \ -e USER_ID=$(id -u) `#运行应用的用户ID` \ -e GROUP_ID=$(id -g) `#运行应用的用户组ID` \ --restart unless-stopped \ stainless403/mdcx-builtin-gui-base:latest
bashcd /path/to/mdcx-docker docker-compose pull docker-compose up -d
注意,只有使用docker-compose方式部署的才能用该方式更新镜像。 另外其实使用docker-compose方式部署的,也可以使用下面说的
watchtower进行更新。
推荐使用watchtower工具更新。
bashdocker run --rm \ -v /var/run/docker.sock:/var/run/docker.sock \ containrrr/watchtower \ --run-once \ 容器名称
个人不太建议自动更新,请自行斟酌。
示例:每天的凌晨2点进行更新
bashdocker run -d --name watchtower-mdcx \ --restart unless-stopped \ -v /var/run/docker.sock:/var/run/docker.sock \ containrrr/watchtower \ -c --schedule "0 0 2 * * *" 容器名称
0 0 2 * * *
6个部分分别为:
秒 分 时 日 月 星期
参考:CRON_Expression_Format
取消定时更新:
bashdocker rm -f watchtower-mdcx
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务