Docker不保留postgres卷[django]

时间:2019-03-21 21:00:35

标签: django postgresql docker docker-compose docker-volume

关于我遇到的类似问题,这里有很多问题,例如thisthisthisthis,但非常相似,但那里没有解决方案可以解决我的问题。请不要关闭此问题。

问题:

我在docker上使用nginx和postgres运行django。机密信息存储在.env文件中。我的postgres数据没有与docker-compose up/startdocker-compose down/stop/restart保持一致。

这是我的docker-compose文件:

version: '3.7'

services:
  web:
    build: ./app
    command: gunicorn umngane_project.wsgi:application --bind 0.0.0.0:8000
    volumes:
      - ./app/:/usr/src/app/
    expose:
      - 8000
    environment:
      - SECRET_KEY=${SECRET}
      - SQL_ENGINE=django.db.backends.postgresql
      - SQL_DATABASE=postgres
      - SQL_USER=${POSTGRESQLUSER}
      - SQL_PASSWORD=${POSTGRESQLPASSWORD}
      - SQL_HOST=db
      - SQL_PORT=5432
      - SU_NAME=${SU_NAME}
      - SU_EMAIL=${SU_EMAIL}
      - SU_PASSWORD=${SU_PASSWORD}
    depends_on:
      - db
  db:
    image: postgres:11.2-alpine
    volumes:
      - postgres_data:/var/lib/postgresql/data/
  nginx:
    build: ./nginx
    volumes:
      - static_volume:/usr/src/app/assets
    ports:
      - 1337:80
    depends_on:
      - web

volumes:
  postgres_data:
    external: true # I tried running without this and the result is the same
  static_volume:

我的入口点密码是这样的:

python manage.py flush --no-input
python manage.py makemigrations
python manage.py migrate
python manage.py createsuperuser --user "${SU_NAME}" --email "${SU_EMAIL}" --password "${SU_PASSWORD}"
python manage.py collectstatic --no-input

exec "$@"

其中createsuperuser是一个自定义模块,可在应用程序中创建一个超级用户。

此设置未将信息保留在postgres_data中。

其他信息:

在执行任何操作之前,我检查是否使用postgres_data没有名为docker volume ls的卷,并且得到了该卷。

这时我运行docker-compose up -d / docker-compose up -d --build,一切正常,没有错误。

我运行docker inspect postgres_data,它显示"CreatedAt": "X1"

我能够以超级用户身份登录。我继续创建管理员用户,以超级用户身份注销,然后以任何管理员用户身份登录都没有问题。我运行docker exec -it postgres_data psql -U <postgres_user>以确保管理员用户在数据库中并找到了。

此时,我可以毫无问题地继续运行docker-compose down / docker-compose stop。我运行docker volume ls,它显示postgres_data仍然存在。

我运行docker inspect postgres_data,它显示"CreatedAt": "X2"

为了测试一切正常,我运行docker-compose up -d / docker-compose up -d --build / docker-compose start / docker-compose restart

我运行docker inspect postgres_data,它显示"CreatedAt": "X3"

这时,我继续尝试以管理员用户身份登录,但无法登录。我再次运行docker exec -it postgres_data psql -U <postgres_user>,但这一次只看到超级用户,没有管理员用户。

(说明:我在这里使用正斜杠显示我在不同尝试中尝试过的所有不同内容。我尝试了此处显示的所有命令组合。)

2 个答案:

答案 0 :(得分:1)

拥有持久数据的一种方法是在磁盘上指定实际路径,而不是创建卷:

...
  db:
    image: postgres:11.2-alpine
    volumes:
      - "/local/path/to/postgres/data:/var/lib/postgresql/data/"
...

这样,容器的postgres数据位置将映射到您指定的路径。这样,除非有意删除,否则数据将直接保留在磁盘上。 据我所知,将在删除容器时删除一个Docker卷。

答案 1 :(得分:0)

问题是您在清除数据库的入口点脚本中运行“刷新”。每当您启动或重新创建容器时,入口点都将运行。