使用 Docker Swarm 内部的“绑定”卷挂载和 docker-compose 文件
Using “bind” volume mount inside of Docker Swarm with a docker-compose file
我的环境使用的是 3 节点 Docker Swarm(都是管理器),我有一个 docker-compose.yaml 是为部署到 Swarm 而创建的。
在我的 docker-compose.yaml 中,我正在设置两项服务,一项是 MySQL 实例,另一项是我的自定义 Django 应用程序。
我想做的有两个方面:
- 我需要将本地目录(示例:/test)挂载到容器中。 host/node/server 上确实存在此文件,我正在尝试将其挂载到容器中存在的文件(示例:/tmp)。
- 创建一个永久数据库文件夹,这样我们的 MySQL 就不会在容器退出时被破坏。
我的问题是我无法获取要在容器内显示的本地主机文件(在本例中为 /test)。我试过同时使用长语法和短语法来创建“绑定挂载”。
这是我的 docker-compose.yaml 文件:
version: '3.2'
services:
project_mysql:
environment:
MYSQL_USER: 'project'
MYSQL_PASSWORD: 'password1234'
ports:
- 3306:3306
image: 'mysql/mysql-server'
tty: true
stdin_open: true
deploy:
mode: replicated
replicas: 1
restart_policy:
condition: on-failure
placement:
constraints:
- node.hostname == node1
healthcheck:
test: ["CMD", "mysqladmin" ,"ping", "-h", "localhost"]
interval: "5s"
timeout: "1s"
project_web:
image: 'localhost:5123/project_web:0.1.5'
tty: true
stdin_open: true
volumes:
- type: bind
source: /test
target: /tmp
ports:
- 8000:8000
depends_on:
- project_mysql
healthcheck:
test: ["CMD-SHELL", "nc -z 127.0.0.1 8000 || exit 1"]
interval: "5s"
timeout: "1s"
networks:
projectnet:
driver: overlay
ipam:
config:
- subnet: 10.2.0.0/24
感谢您的帮助!
您需要将命名卷添加到 docker-compose.yaml 文件。
在启动实例之前,运行
docker volume create mysql-data
然后,在 docker-compose.yaml
添加:
services:
project_mysql:
volumes:
- mysql-data:/var/lib/mysql
volumes:
mysql-data:
external: true
如果您终止该服务,数据仍会保留。
我的环境使用的是 3 节点 Docker Swarm(都是管理器),我有一个 docker-compose.yaml 是为部署到 Swarm 而创建的。
在我的 docker-compose.yaml 中,我正在设置两项服务,一项是 MySQL 实例,另一项是我的自定义 Django 应用程序。
我想做的有两个方面:
- 我需要将本地目录(示例:/test)挂载到容器中。 host/node/server 上确实存在此文件,我正在尝试将其挂载到容器中存在的文件(示例:/tmp)。
- 创建一个永久数据库文件夹,这样我们的 MySQL 就不会在容器退出时被破坏。
我的问题是我无法获取要在容器内显示的本地主机文件(在本例中为 /test)。我试过同时使用长语法和短语法来创建“绑定挂载”。
这是我的 docker-compose.yaml 文件:
version: '3.2'
services:
project_mysql:
environment:
MYSQL_USER: 'project'
MYSQL_PASSWORD: 'password1234'
ports:
- 3306:3306
image: 'mysql/mysql-server'
tty: true
stdin_open: true
deploy:
mode: replicated
replicas: 1
restart_policy:
condition: on-failure
placement:
constraints:
- node.hostname == node1
healthcheck:
test: ["CMD", "mysqladmin" ,"ping", "-h", "localhost"]
interval: "5s"
timeout: "1s"
project_web:
image: 'localhost:5123/project_web:0.1.5'
tty: true
stdin_open: true
volumes:
- type: bind
source: /test
target: /tmp
ports:
- 8000:8000
depends_on:
- project_mysql
healthcheck:
test: ["CMD-SHELL", "nc -z 127.0.0.1 8000 || exit 1"]
interval: "5s"
timeout: "1s"
networks:
projectnet:
driver: overlay
ipam:
config:
- subnet: 10.2.0.0/24
感谢您的帮助!
您需要将命名卷添加到 docker-compose.yaml 文件。
在启动实例之前,运行docker volume create mysql-data
然后,在 docker-compose.yaml
添加:
services:
project_mysql:
volumes:
- mysql-data:/var/lib/mysql
volumes:
mysql-data:
external: true
如果您终止该服务,数据仍会保留。