LoginSignup
65
55

More than 5 years have passed since last update.

Docker for Windowsでpostgresのデータマウントができない人へ

Posted at

Docker for macで動くけどDocker for windowsで苦戦している人は私以外にもいるはず

過去の私のブログ記事

ここでは、postgresのvolumeマウントについての解決策が見つかったので紹介。

postgresのデータ永続化

postgresのデータ永続化のために、
-v ./postgres-db:/var/lib/postgresql/data

docker-compose.yml
volumes:
  - ./postgres-db:/var/lib/postgresql/data

のようなオプション設定をして、has wrong ownershipといった形でエラーをはくことがDocker for windowsでは起こる。
これは公式issueでも言及されている問題の模様

issue docker/for-win

解決法としては、volumeコマンドを使ってデータを永続化させてあげることが無難だと判断した。
参考

http://www.lukaszewczak.com/2016/09/run-postgresql-using-docker-with.html

と、いうことで解決法。
サンプルのdocker-composeファイルを紹介

docker-compose.yml
version: '2'
services:
  db:
    image:
      postgres
    ports:
      - "5432"
    volumes:
      - test_db:/var/lib/postgresql/data
      - ./docker-entrypoint-initdb.d:/docker-entrypoint-initdb.d

volumes:
  test_db:
    external: true

postgresのみを一部抜粋。
最後のvolumesで、外部(composeの外)のvolumeを探してきてマウントします

http://docs.docker.jp/compose/compose-file.html#external

したがって、
docker volume create --name test_db
とした後に、
docker-compose up
とすることで、Docker for Windowsでも問題なく動作することを確認したので備忘録的に載せておきます。
ちなみに、mysqlではこのようなエラーは起こりません

65
55
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
65
55