在docker中使用Mysql无法在\'db \'Django-Restframework上连接到MySQL服务器

时间:2018-11-03 07:18:26

标签: python mysql django docker django-rest-framework

我已经泊坞化了使用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")')

1 个答案:

答案 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)上使用重启策略来自动重启服务(直到数据库启动)。