Использование «привязки» монтирования тома внутри Docker Swarm с файлом docker-compose

В моей среде используется 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

Спасибо за любую помощь!


person gwinterbo    schedule 01.08.2018    source источник
comment
Нашли ли вы решение, позволяющее иметь том на одном узле и получать к нему доступ с других узлов?   -  person SScholl    schedule 10.12.2018


Ответы (1)


Вам нужно добавить именованные тома в файл 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

Если вы когда-нибудь убьете службу, данные все равно сохранятся.

person Joel Magnuson    schedule 02.08.2018
comment
А вы уверены, что его уберут, если вы закажете услугу? С помощью docker-compose не внешние именованные тома не будут удалены. - person SScholl; 10.12.2018