【发布时间】:2021-10-03 12:08:25
【问题描述】:
似乎是一个常见错误。我遵循了关于 Stackoverflow 的所有可能建议(添加链接、网络等),但在我的情况下没有任何区别。我在 Windows 上运行。
我的 Dockerfile:
#Pull base image.
FROM python:3.9.5-slim
#Usefull to get logs
ENV PYTHONUNBUFFERED 1
#Make local dir
RUN mkdir -p /app
#set as the working directory
WORKDIR /app
#https://luis-sena.medium.com/creating-the-perfect-python-dockerfile-51bdec41f1c8
COPY requirements.txt .
#now copy all the files in this directory to \code
ADD . .
#https://testdriven.io/blog/dockerizing-django-with-postgres-gunicorn-and-nginx/
RUN apt-get update && \
apt-get install -y postgresql-server-dev-all gcc python3-dev musl-dev && \
pip install -r requirements.txt && \
adduser --disabled-password --no-create-home app
USER app
#CMD python manage.py runserver
CMD gunicorn --bind 0.0.0.0:8000 app.wsgi:application -k eventlet
接下来,我的 docker-compose.yml:
services:
web:
build: .
ports:
- "8000:8000"
volumes:
- .:/app
links:
- db:db
container_name: heritageapi_web_1
depends_on:
- db
networks:
- heritage-network
db:
image: postgres:13.3
container_name: db
restart: always
networks:
- heritage-network
environment:
POSTGRES_DATABASE: admin
POSTGRES_USER: root
POSTGRES_PASSWORD: root
POSTGRES_ROOT_PASSWORD: root
volumes:
- .dbdata:/var/lib/postgres
ports:
- "32768:5432"
networks:
heritage-network:
driver: bridge
我的 .env:DB_NAME=admin DB_USER=root DB_PASSWORD=root DB_HOST=db DB_PORT=5432
最后是我的 settings.py:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql',
'NAME': os.getenv('DB_NAME'),
'USER': os.getenv('DB_USER'),
'PASSWORD': os.getenv('DB_PASSWORD'),
'HOST': os.getenv('DB_HOST'),
'PORT': os.getenv('DB_PORT'),
}
}
【问题讨论】:
-
不应该是:
os.getenv('POSTGRES_DATABASE')?其他env变量也应该更改吗?
标签: python django postgresql docker django-rest-framework