我已经泊坞化了使用MySQL数据库的现有Django Rest项目。
文档文件
FROM python:3.6
ENV PYTHONUNBUFFERED 1
RUN mkdir /code
WORKDIR /code
COPY . /code/
RUN pip install -r requirements.txt
requirements.txt
django
djongo
django-rest-framework
车轮
枕头
mysqlclient
django-cors-headers
docker-compose.yml
version: '3'
volumes:
portainer:
services:
db:
image: mysql
environment:
MYSQL_ROOT_PASSWORD: docker
MYSQL_DATABASE: docker
MYSQL_USER: docker
MYSQL_PASSWORD: docker
ports:
- "3306:3306"
web:
build: .
command: bash -c "python manage.py makemigrations && python manage.py migrate && python manage.py runserver 0.0.0.0:8000 "
volumes:
- .:/code
ports:
- "8000:8000"
links:
- db
portainer:
image: portainer/portainer
ports:
- "9000:9000"
volumes:
- /var/run/docker.sock:/var/run/docker.sock
- portainer:/data
setting.py
'ENGINE': 'django.db.backends.mysql', #django.db.backends.mysql
'NAME': 'docker', #local: libraries #server:
'USER': 'docker', #root #root
'PASSWORD': 'docker', #local: root #server:
'HOST': 'db', #local: localhost #server:
'PORT': '3306',
我的命令'docker-compose up -d --build'成功,但是restapp容器未启动,因此在检查日志时它显示此错误django.db.utils.OperationalError: (2003, 'Can\'t connect to MySQL server on \'db\' (111 "Connection refused")')
。
答案 0 :(得分:0)
如果您的应用程序容器(此处为web
)在数据库完全初始化之前启动,则可能会发生这种情况。
在启动应用程序(db
)之前,您必须等待mysql
服务启动(更确切地说,直到python manage.py makemigrations && python manage.py migrate && python manage.py runserver 0.0.0.0:8000
接受连接)。
为此,您可以在运行python命令之前使用wait-for-it.sh
脚本(选中https://docs.docker.com/compose/startup-order/)。另外,您可以在web
服务(https://docs.docker.com/compose/compose-file/#restart_policy)上使用重启策略来自动重启服务(直到数据库启动)。