【发布时间】:2019-01-09 13:25:52
【问题描述】:
我的环境使用的是 3 节点 Docker Swarm(都是管理器),我有一个 docker-compose.yaml,它被创建用于部署到 Swarm。
在我的 docker-compose.yaml 中,我设置了两个服务,一个是 MySQL 实例,另一个是我的自定义 Django 应用程序。
我想做的是两方面的:
- 我需要将本地目录(例如:/test)挂载到容器中。该文件确实存在于主机/节点/服务器上,我正在尝试将其挂载到容器中存在的文件(例如:/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 docker-compose docker-swarm docker-volume