docker-compose:postgres数据不持久

时间:2015-04-24 15:59:27

标签: postgresql sqlalchemy docker boot2docker docker-compose

我的docker-compose文件中有一个使用postgres图像的主服务,虽然我似乎成功连接到数据库,但我写的数据不是保持超出容器的生命周期(我所做的是基于this tutorial)。

这是我的docker-compose文件:

main:
  build: .
  volumes:
    - .:/code
  links:
    - postgresdb
  command: python manage.py insert_into_database
  environment:
    - DEBUG=true


postgresdb:
  build: utils/sql/
  volumes_from:
    - postgresdbdata
  ports:
    - "5432"
  environment:
    - DEBUG=true


postgresdbdata:
  build: utils/sql/
  volumes:
    - /var/lib/postgresql
  command: true
  environment:
    - DEBUG=true

这是我用于postgresdbpostgresdbdata服务的Dockerfile(实质上是创建数据库并添加用户):

FROM postgres

ADD make-db.sh /docker-entrypoint-initdb.d/

如何在main服务运行完毕后才能保留数据,以便将来能够使用它(例如当我调用python manage.py retrieve_from_database之类的内容时)? /var/lib/postgresql是否是正确的目录,boot2docker是否可以访问它,因为它显然仅限于/Users/

谢谢!

1 个答案:

答案 0 :(得分:6)

问题是Compose每次重新启动时都会创建一个 new 版本的postgresdbdata容器,因此旧容器及其数据会丢失。

第二个问题是您的数据容器实际上不应该运行;数据容器实际上只是一个可以使用--volumes-from导入的卷的命名空间,它仍可用于已停止的容器。

目前最好的解决方案是将postgresdbdata容器从Compose配置中取出。做类似的事情:

$ docker run --name postgresdbdata postgresdb echo "Postgres data container"
Postgres data container

echo命令将运行并且容器将退出,但只要不docker rm它,您仍然可以在--volumes-from中引用它并且您的Compose应用程序应该可以正常工作