我有一个docker-compose的配置,在构建数据库步骤时,Django管理抛出错误:
django.db.utils.OperationalError:(2002年,“无法连接到'127.0.0.1'(115)上的MySQL服务器”)
我认为-码头工人拒绝连接。
类似的套接字配置无法正常工作(error connection by socket
)
Docker Compose文件
version: '3'
services:
db:
image: mariadb:5.5
restart: always
environment:
MYSQL_ROOT_PASSWORD: "root"
MYSQL_DATABASE: "bh"
MYSQL_USER: "root"
MYSQL_PASSWORD: "root"
ports:
- "3302:3306"
behealthy_dev:
build: .
container_name: behealthy_dev
expose:
- "86"
command: python manage.py runserver 0.0.0.0:80
volumes:
- /behealthy_dev/
ports:
- "86:86"
depends_on:
- db
Dockerfile
FROM python:3.6
ENV PYTHONUNBUFFERED 1
RUN mkdir /behealthy_dev
WORKDIR /behealthy_dev
ADD requirements.txt /behealthy_dev/
RUN pip install -r requirements.txt
ADD . /behealthy_dev/
RUN python manage.py makemigrations
RUN python manage.py migrate
RUN python manage.py collectstatic --noinput
数据库设置(设置)
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'bh',
'HOST': '127.0.0.1',
'PORT': '3306',
'USER': 'root',
'PASSWORD': 'root',
'OPTIONS': {
'sql_mode': 'traditional',
'init_command': 'SET innodb_strict_mode=1',
'charset': 'utf8mb4',
},
},
}
有什么解决方案吗?我试图从其他堆栈答案中解决,但它对我不起作用。
答案 0 :(得分:0)
在您的服务behealthy_dev
中,从
'HOST': '127.0.0.1'
到
'HOST': 'db',
编辑:
也将MYSQL_ROOT_PASSWORD: "root"
更改为:
`MYSQL_ROOT_PASSWORD: "rootpassword"`
和您的数据库设置为:
'PASSWORD': 'rootpassword',
答案 1 :(得分:0)
但是我的mysql服务器配置良好,可以用于root用户。 docker conf问题