Я пытаюсь создать резервную копию/восстановить базу данных PostgreSQL, как описано на веб-сайте Docker, но данные не восстановлены.
Томами, используемыми в образе базы данных, являются:
VOLUME ["/etc/postgresql", "/var/log/postgresql", "/var/lib/postgresql"]
и CMD:
CMD ["/usr/lib/postgresql/9.3/bin/postgres", "-D", "/var/lib/postgresql/9.3/main", "-c", "config_file=/etc/postgresql/9.3/main/postgresql.conf"]
Я создаю контейнер БД с помощью этой команды:
docker run -it --name "$DB_CONTAINER_NAME" -d "$DB_IMAGE_NAME"
Затем я подключаю другой контейнер для вставки некоторых данных вручную:
docker run -it --rm --link "$DB_CONTAINER_NAME":db "$DB_IMAGE_NAME" sh -c 'exec bash'
psql -d test -h $DB_PORT_5432_TCP_ADDR
# insert some data in the db
<CTRL-D>
<CTRL-D>
Затем создается архив tar:
$ sudo docker run --volumes-from "$DB_CONTAINER_NAME" --rm -v $(pwd):/backup ubuntu tar cvf /backup/backup.tar /etc/postgresql /var/log/postgresql /var/lib/postgresql
Теперь я удаляю контейнер, используемый для db, и создаю еще один, с тем же именем, и попытаюсь восстановить ранее вставленные данные:
$ sudo docker run --volumes-from "$DB_CONTAINER_NAME" --rm -v $(pwd):/backup ubuntu tar xvf /backup/backup.tar
Но таблицы пустые, почему данные не восстановлены должным образом?