我对docker非常陌生,现在我尝试通过docker-compose在docker中运行django和mariadb,但是我总是收到以下错误:
我使用的版本是:Docker version 17.09.1-ce, build 19e2cf6
, docker-compose version 1.18.0, build 8dd22a9
django.db.utils.OperationalError: (2003, '无法连接到MySQL服务器\'mariadb55\'(111 "Connection refused")')
在本地或远程运行docker-compose up db
后,我可以正确连接数据库,并且我甚至可以在anaconda虚拟环境中正确运行python manage.py runserver 0.0.0.0:6001
以通过settings.py文件设置参数来连接docker中的db
服务。
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': 'test',
'USER': 'belter',
# 'HOST': 'mariadb55',
'HOST': '127.0.0.1',
'PORT': '3302',
'PASSWORD': 'belter_2017',
'default-character-set': 'utf8',
'OPTIONS': {
'sql_mode': 'traditional',
}
}
}
这是我的 docker-compose.yml 文件。
version: '3'
services:
db:
image: mariadb:5.5
restart: always
environment:
- MYSQL_HOST=localhost
- MYSQL_PORT=3306
- MYSQL_ROOT_HOST=%
- MYSQL_DATABASE=test
- MYSQL_USER=belter
- MYSQL_PASSWORD=belter_2017
- MYSQL_ROOT_PASSWORD=123456_abc
volumes:
- /home/belter/mdbdata/mdb55:/var/lib/mysql
ports:
- "3302:3306"
web:
image: onlybelter/django_py35
command: python3 manage.py runserver 0.0.0.0:6001
volumes:
- /mnt/data/www/mysite:/djcode
ports:
- "6001:6001"
depends_on:
- db
links:
- db:mariadb55
我尽可能尝试了所有可以找到的方法,但仍然无法解决问题,希望能得到帮助!
我已经尝试过以下方法:
docker-compose.yml
文件中 MySQL 服务在哪里? - Janshair Khanmariadb
,它们是相同的。 - Belter