在Docker Swarm中使用“绑定”卷安装与docker-compose文件

时间:2018-08-01 21:13:25

标签: docker docker-compose docker-swarm docker-volume

我的环境正在使用3节点Docker Swarm(都是管理员),我创建了一个docker-compose.yaml来部署到Swarm。

在我的docker-compose.yaml中,我正在设置两个服务,一个是MySQL实例,另一个是我的自定义Django应用。

我想做的事有两个方面:

  1. 我需要在容器中挂载本地目录(例如:/ test)。该文件确实存在于主机/节点/服务器上,并且我试图将其安装到容器中存在的文件中(例如:/ tmp)。
  2. 创建一个持久数据库文件夹,以便在容器退出时不会破坏我们的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

感谢您的帮助!

1 个答案:

答案 0 :(得分:0)

您需要将命名卷添加到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

如果您终止了该服务,数据仍将保留。