Docker для Windows: монтирование томов не работает с dockerized postgresql - PullRequest
0 голосов
/ 01 февраля 2019

Я использую Docker на компьютере с Windows 10.Я пытаюсь запустить dockerized базу данных postgresql, чьи данные можно смонтировать на моем компьютере с Windows 10Затем я хочу иметь возможность отправить эти данные базы данных в хранилище GitLab.Если после этого какой-либо другой пользователь захочет использовать новейшую версию базы данных, ему просто нужно извлечь изменения и затем смонтировать данные на закрепленном postgresql.

Почему я хочу это сделать?

У нас будет много изменений в этой базе данных.Люди также работают одновременно над другой версией нашей программы.С постоянной базой данных мне нужно было бы управлять различными версиями базы данных для каждой отдельной ветви функций, разрабатывать ветки и ветки master / release.Это слишком много, чтобы справиться.Таким образом, в идеале любые изменения, сделанные в базе данных для конкретной ветви функций, можно найти только в этой конкретной ветви функций.Там не будет никаких конфликтов.Это также позволяет экспериментировать с базой данных, не разрушая ее для любого другого пользователя.

Ну, в чем же тогда проблема?

Docker для Windows поставляется с ограничениями, см .: https://github.com/docker/for-win/issues/445

TL; DR: сейчас невозможно смонтировать томаиз Windows в контейнеры Linux.Для этого есть обходные пути, как сказано в ссылке, но нет необходимости получать эти данные из базы данных, активно передавать их / делиться ими и т. Д., А просто сохранять базу данных в локальной системе.

Ну, я попробовал почти все, что придумал мой разум:

Сделал docker-compose, использовал именованные тома, и я также попытался использовать

/c/this/is/my/windows/path:this/is/my/linux/path

вместо

C:\this\is\my\windows\path:this/is/my/linux/path

но это тоже не помогло.

Я также использовал, как уже говорилось, именованные тома в файле docker-compose:

version: '3'
services: 
  postgres:
    image: postgres
    environment:
      - POSTGRES_USER=postgres
      - POSTGRES_PASSWORD=postgress
      - POSTGRES_DB=lol
  ports:
      - "5432:5432"
  volumes: 
      - data:/var/lib/postgresql/data

volumes:
  data: {}

Но угадайте, что: Это все равно не удалось.

Я знаю, что могу создать дамп своей базы данных и отправить его, но проблема здесь в следующем: я не хочу делать это вручную все время.Я бы предпочел гладкое решение без создания и загрузки дампа каждый раз.Я просто хочу запустить файл docker-compose, который монтирует данные базы данных, и все: очень простое и приятное решение.

...