docker-compose 有两个容器:web 无法连接到 db

Swi*_*avy 9 django postgresql containers docker docker-compose

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
Run Code Online (Sandbox Code Playgroud)

在我的settings.py数据库部分:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': INSTANCE_NAME,
        'USER': 'postgres',
        'PASSWORD': 'postgres',
        'HOST': 'db',
        'PORT': '5432'
    },

}
Run Code Online (Sandbox Code Playgroud)

当我运行时$ docker-compose up -d,第一个图像 (db) 被创建并启动它的容器。可以看到它的运行,并侦听端口5432docker pslsof。如果我web:docker-compose.yml文件中删除组件,也会发生同样的事情

现在,第二个组件 (web) 的 Dockerfile 包含以下两行(以及许多其他行):

RUN python manage.py makemigrations myapp
RUN python manage.py migrate
Run Code Online (Sandbox Code Playgroud)

“迁移”之类的会因此错误而死:

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?
Run Code Online (Sandbox Code Playgroud)

我累了几次调整。* 更改version '3.7' * 添加到数据库部分

expose:
    - "5432"
Run Code Online (Sandbox Code Playgroud)
  • 添加到网络组件:

depends_on: - "db"

  • 添加到网络组件:

links: - "db"

  • 将 PRODUCTION 设置为 false

environment: PRODUCTION: 'false'

  • 将 HOST 更改settings.py为容器名称、图像名称、标签、容器 ID、'localhost'、'127.0.0.1' 等。错误是相同的,只是提到了新的 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
Run Code Online (Sandbox Code Playgroud)

然后我构建 myapp-web:

docker build -t myapp-web .
Run Code Online (Sandbox Code Playgroud)

同样的错误仍然发生。那么,为什么现在找不到 db 容器呢?

小智 0

我知道这可能看起来非常基本,但为什么不考虑一种更复杂的命名约定,然后简单地将这些名称添加到主机上的 DNS 服务中,或者至少添加到 A 记录中?

然后系统可以通过名称或IP 访问数据库。只是一个想法。

顺便说一句,平台和语言的绝佳选择和组合,Django + PostgreSQL 是我的最爱。我还推荐 Bootstrap,特别是如果您正在寻找快速工具部署功能。