【发布时间】:2019-06-18 07:53:04
【问题描述】:
docker-compose 构建 web 组件失败,因为它无法连接到之前创建的 db 组件
Mac OSX 10.13.6、conda 4.5.11、Python 3.6.8、Docker 版本 18.09.1、docker-compose 版本 1.23.2
django 1.8.3 使用 Dockerfile 中的 requirements.txt 进行安装。不能随意升级。
关于 SO 的几个非常相似的讨论没有帮助(比如这个:Docker-compose with django could not translate host name "db" to address: Name or service not known)。
我有一个docker-compose.yml,有一个网络和两个组件:
version: '3'
networks:
bridge:
driver: bridge
services:
db:
image: postgres:10
container_name: myapp-db
volumes:
- ./postgres_data:/var/lib/postgresql/data/
ports:
- "5432:5432"
environment:
POSTGRES_DB: actionability-master
POSTGRES_PASSWORD: postgres
POSTGRES_USER: postgres
networks:
- bridge
web:
restart: unless-stopped
container_name: myapp-web
build: .
command: /start_gunicorn.sh
ports:
- "8080:8080"
environment:
PRODUCTION: 'true'
networks:
- bridge
在我的settings.py 我有数据库部分:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'NAME': INSTANCE_NAME,
'USER': 'postgres',
'PASSWORD': 'postgres',
'HOST': 'db',
'PORT': '5432'
},
}
当我运行$ docker-compose up -d 时,
第一个图像 (db) 被创建并且它的容器被启动。
可以看到它正在使用 docker ps 和 lsof 在端口 5432 上运行和侦听。如果我从 docker-compose.yml 文件中删除 web: 组件,也会发生同样的事情
现在,第二个组件(网络)的 Dockerfile 包含这两行(以及许多其他行):
RUN python manage.py makemigrations myapp
RUN python manage.py migrate
“迁移”喜欢死于此错误:
Traceback (most recent call last):
File "/usr/local/lib/python3.6/site-packages/django/db/backends/base/base.py", line 130, in ensure_connection
self.connect()
File "/usr/local/lib/python3.6/site-packages/django/db/backends/base/base.py", line 119, in connect
self.connection = self.get_new_connection(conn_params)
File "/usr/local/lib/python3.6/site-packages/django/db/backends/postgresql_psycopg2/base.py", line 176, in get_new_connection
connection = Database.connect(**conn_params)
File "/usr/local/lib/python3.6/site-packages/psycopg2/__init__.py", line 130, in connect
conn = _connect(dsn, connection_factory=connection_factory, **kwasync)
psycopg2.OperationalError: could not connect to server: Connection refused
Is the server running on host "db" (37.34.32.51) and accepting TCP/IP connections on port 5432?
我厌倦了几次调整。
* 更改version '3.7'
* 添加到数据库部分
expose:
- "5432"
- 添加到网络组件:
depends_on:
- "db"
- 添加到网络组件:
links:
- "db"
- 将 PRODUCTION 设置为 false
environment:
PRODUCTION: 'false'
- changed HOST in
settings.pyto container name, to image name, to tags, to container id, to 'localhost', to '127.0.0.1', etc..错误是一样的,只是提到新的HOST名称而不是 'db' - 在 conda env 之外运行
- 使用
--build开关(docker-compose up -d --build)运行 -
docker system prune又跑了
都是一样的错误。
更新: 在建议它 docker-compose 不能以这种方式工作后,我尝试将其拆分为两个单独的任务。首先,我构建 myapp-db 容器并确保它在正确的端口上运行:
$ docker container ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
c110e8361cda postgres:10 "docker-entrypoint.s…" 4 hours ago Up 4 hours 0.0.0.0:5432->5432/tcp myapp-db
然后我构建 myapp-web:
docker build -t myapp-web .
同样的错误仍然发生。那么,为什么现在找不到 db 容器?
【问题讨论】:
-
the second component (web) has Dockerfile that contains these two lines,这是正在运行的 Web 容器中的 Dockerfile,还是 Web 容器的 Dockerfile? -
您的 RUN 命令总是在 BUILD 时执行,而不是在运行时。因此,当您构建映像时,您的数据库将不存在,因为没有数据库。所以你不能这样做
-
谢谢@SvenHakvoort,我想我明白了。 docker-compose 不能这样工作,db 组件在 docker-compose.yml 中的 web 容器之前这一事实并不意味着它的容器在 web 容器正在构建时已经启动并运行,对吧?
-
@bluescores 是 Web 组件的 Dockerfile,它正在构建其映像并由 docker-compose 启动其容器(如果工作:-))
标签: django postgresql docker docker-compose containers