python - 无法连接到 'db' 上的 MySQL 服务器([Errno -2] 名称无法解析)

标签 python django docker

我正在尝试使用 python 连接 mysql 和 docker。但这个错误正在发生。我用的是python3。我是 Docker 新手,所以我找不到任何解决方案。

Dockerfile:

FROM python:3.8-alpine
MAINTAINER Fahim Ahmed Irfan

ENV PYTHONUNBUFFERED 1

COPY ./requirements.txt /requirements.txt
RUN apk add --update --no-cache jpeg-dev
RUN apk --update add --no-cache --virtual .tmp-build-deps \
      gcc build-base libffi-dev freetype-dev libpng-dev openblas-dev linux-headers mysql-dev zlib zlib-dev
RUN pip install -r /requirements.txt

RUN mkdir /app
WORKDIR ./app
COPY ./app /app

RUN adduser -D user
User user
EXPOSE 8000

Docker 撰写文件:

version: '3'

services:
  app:
    restart: always
    build:
      context: .
    ports:
      - "8000:8000"
    volumes:
      - ./app:/app
    command: >
      sh -c "python check_db.py --service-name mysql --ip db --port 3306 &&
             python manage.py makemigrations &&
             python manage.py migrate &&
             python manage.py runserver 0.0.0.0:8000"
    environment:
      - DB_HOST=db
      - DB_NAME=app
      - DB_USER=root
      - DB_PASS=supersecretpassword
    depends_on:
      - db

  db:
    image: mysql:8.0
    environment:
      - MYSQL_HOST=localhost
      - MYSQL_PORT=3306
      - MYSQL_ROOT_HOST=%
      - MYSQL_DATABASE=app
      - MYSQL_USER=root
      - MYSQL_PASSWORD=supersecretpassword

    ports:
      - "3306:3306"

check_db.py:

import socket
import time
import argparse
""" Check if port is open, avoid docker-compose race condition """

parser = argparse.ArgumentParser(description='Check if port is open, avoid\
                                 docker-compose race condition')
parser.add_argument('--service-name', required=True)
parser.add_argument('--ip', required=True)
parser.add_argument('--port', required=True)

args = parser.parse_args()

# Get arguments
service_name = str(args.service_name)
port = int(args.port)
ip = str(args.ip)

# Infinite loop
while True:
    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    result = sock.connect_ex((ip, port))
    if result == 0:
        print("{0} port is open! Bye!".format(service_name))
        break
    else:
        print("{0} port is not open! I'll check it soon!".format(service_name))
        time.sleep(3)

设置.py:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'HOST': os.environ.get('DB_HOST'),
        'NAME': os.environ.get('DB_NAME'),
        'USER': os.environ.get('DB_USER'),
        'PASSWORD': os.environ.get('DB_PASS'),
        'PORT': '3306',
    }

需求.txt:

Django==2.1.3,<2.2.0
djangorestframework==3.9.0,<3.10.0
pymysql

错误是:django.db.utils.OperationalError:(2003,“无法连接到'db'上的MySQL服务器([Errno -2]名称无法解析)”)

不知道如何解决这个问题。请指教。

最佳答案

终于我成功了,我对您的代码进行了一些重要的更改。

WORKDIR app

WORKDIR 创建目录 app 并移动到目录 app 中,以便您可以删除语句 RUN mkdir/应用程序 由于您也移动到该目录,因此将 COPY 语句更改为

COPY . .

第一个.是dockerfile存在的地方,第二个.是容器中的app文件夹。因此,将 dockerfile 放在应用程序文件夹中总是好的。

    volumes:
      - ./app:/app

不需要 docker-compose 中的上述代码,因为您直接复制内容,因此再次挂载是没有用的。

      - MYSQL_ROOT_PASSWORD=supersecretpassword

另外,将上述环境变量添加到docker-compose中的db服务

- MYSQL_HOST=localhost

请删除此环境变量,因为此处不需要它。

image: mysql:5.7

我建议使用版本 5.7,因为它是我广泛使用的稳定版本之一,数据库服务器没有出现很多问题。

关于python - 无法连接到 'db' 上的 MySQL 服务器([Errno -2] 名称无法解析),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62063499/

相关文章:

ruby-on-rails - 执行 docker-compose up 时无法在任何来源 (Bundler::GemNotFound) 中找到 sprockets-3.6.2

python - 什么编码看起来完全像 ASCII 但每个字节前都有 NULL 字节?

python - Django - 遵循外键关系(即 SQL 中的 JOIN)

python - 无法使用 Python 2.7 从 django 网站连接到 MySQL,但使用 Python 2.5 可以

selenium - Docker selenium/node-chrome - Protractor 找不到 Chrome 二进制文件

python - 无法使用pydevd-pycharm连接到远程调试服务器

python - Python Flask中的整数错误

python - import_meta_graph 失败,数据丢失 : not an sstable (bad magic number)

python - 使用 while 循环过滤 Pandas DataFrame

python - 覆盖应用程序的静态文件?