1. ホーム
  2. データベース

[解決済み】ドッカー化したPostgreSQLデータベースのバックアップ/リストア

2022-04-20 10:07:07

質問

Dockerのサイトで説明されているようにPostgreSQLのデータベースをバックアップ/リストアしようとしていますが、データがリストアされないのですが、どうしたらいいですか?

データベースイメージで使用するボリュームは

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"]

このコマンドでDBコンテナを作成します。

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 

しかし、テーブルは空です。なぜ、データが正しく復元されないのでしょうか?

どうすればいいですか?

データベースのバックアップ

docker exec -t your-db-container pg_dumpall -c -U postgres > dump_`date +%d-%m-%Y"_"%H_%M_%S`.sql

データベースのリストア

cat your_dump.sql | docker exec -i your-db-container psql -U postgres