stainless403/mdcx-src-gui-base,是基于 jlesage/baseimage-gui 构建的适合python+QT5应用运行的镜像。
优点是
轻量
,缺点是只支持通过网页查看,且没有文件管理。
复制以下命令到终端运行,第一步选择模版 3) mdcx-src-gui-base
,然后根据提示输入几个参数即可完成部署。
使用curl:
bash -c "$(curl -fsSL https://raw.githubusercontent.com/northsea4/mdcx-docker/main/install.sh)"
使用wget:
bash -c "$(wget https://raw.githubusercontent.com/northsea4/mdcx-docker/main/install.sh -O -)"
以下的步骤是手动部署的详细说明,即使使用了脚本部署,也请务必阅读一下了解更多细节,如安全、更新等。
stainless403/mdcx-src-gui-base镜像没有内置MDCx,如果想使用内置的,请使用stainless403/mdcx-builtin-gui-base镜像(🔗 查看部署说明)。
Tips: mdcx-src-gui-base支持运行已编译的应用,但mdcx-builtin-gui-base默认情况下不能运行应用源码。
下面主要讲述docker-compose
的部署方式。docker-run
的方式也有简单的示例。
下载 示例项目,解压到合适的位置后,进入项目目录,之后的操作,如无特别说明,都是在该目录(假设名为mdcx-docker
)内进行。
- 执行
update-src.sh
即可自动下载源码到app
目录。
./update-src.sh
整个项目的结构大致如下:
mdcx-docker
|-- app ------应用源码目录
|-- libs
|-- resources
|-- src
|-- main.py
|-- requirements.txt
|-- setup.py
...
|-- data ------容器系统数据
...
|-- mdcx-config --------应用配置文件目录
|-- config.ini
|-- MDCx.config
|-- logs --------应用日志目录
|-- 2023-02-04-01-15-00.txt
|-- .env ------环境变量文件
|-- .env.sample ------环境变量示例文件
|-- .env.versions ------应用版本文件
|-- mdcx-builtin.sample.yml
|-- mdcx-src.sample.yml -------容器部署配置示例
|-- docker-compose.yml -------容器部署配置
|-- update-app.sh
编辑.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 | 否 |
version: '3'
services:
mdcx:
image: stainless403/mdcx-src-gui-base:${MDCX_SRC_IMAGE_TAG}
container_name: ${MDCX_CONTAINER_NAME}
env_file:
- .env
volumes:
# 系统数据目录
- ./data:/config
# 源码目录
- ./app:/app
# 配置文件目录
- ./mdcx-config:/mdcx-config
# `配置文件目录`标记文件
- ./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
docker-compose up -d
# 查看容器日志,容器名称请根据实际情况修改
# docker logs -f mdcx_gui
# 或者
# docker-compose logs -f
首次运行时会自动安装依赖,并在app目录 和 容器内的
/tmp
目录生成一个名为.mdcx_initialized
的标记文件。 当启动脚本检查到这两个文件同时存在时,就认为已安装过依赖。而当重建容器时,由于新容器里没有标记文件,所以会进行一次安装依赖的处理。 如果由于网络等原因没有成功安装依赖,但.mdcx_initialized
又已生成,删除app目录下的.mdcx_initialized
文件即可(容器内的标记文件不需要删除)。
假设服务器IP为192.168.1.100
,使用默认端口5800
,则访问地址为:http://192.168.1.100:5800
/path/to/
替换为你实际的路径。
# 选一个合适的目录
MDCX_DOCKER_DIR=/path/to/mdcx-docker
mkdir -p $MDCX_DOCKER_DIR && cd $MDCX_DOCKER_DIR
# 必须:相关数据或日志目录
mkdir -p app mdcx-config logs data
# 必须:配置文件目录标记文件
echo "/mdcx-config/config.ini" > mdcx-config/MDCx.
# 确保有config.ini文件
touch mdcx-config/config.ini
# !!!下载源码!!!最方便的就是使用`update-src.sh`脚本,自动下载源码文件到`app`目录
./update-src.sh
docker run -d --name mdcx \
-p 5800:5800 `#Web访问端口` \
-p 5900:5900 \
-v $(pwd)/app:/app `#源码目录,请确保已下载好源码` \
-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-src-gui-base:latest
cd /path/to/mdcx-docker
# 确保有执行权限(执行一次即可)
chmod +x ./update-src.sh
./update-src.sh --verbose
# 完成更新源码之后,重启容器
# docker restart mdcx_src_gui
⚠️ 如果你选择不使用脚本而是手动进行更新,请记得删除app
目录下的.mdcx_initialized
文件!
cd /path/to/mdcx-docker
docker-compose pull
docker-compose up -d
注意,只有使用docker-compose方式部署的才能用该方式更新镜像。 另外其实使用docker-compose方式部署的,也可以使用下面说的
watchtower
进行更新。
推荐使用watchtower
工具更新。
- 一次性更新
docker run --rm \
-v /var/run/docker.sock:/var/run/docker.sock \
containrrr/watchtower \
--run-once \
容器名称
- 定时任务方式:
个人不太建议自动更新,请自行斟酌。
示例:每天的凌晨2点进行更新
docker 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个部分分别为:
秒 分 时 日 月 星期
取消定时更新:
docker rm -f watchtower-mdcx