具有docker stack的网络IP

时间:2019-01-17 13:28:22

标签: docker nginx

我终于成功创建了一个可行的Docker配置。在docker-compose.yml文件中,我创建4个服务:数据库(在我的情况下为PostgreSQL),Daphne(用于WS请求),Gunicorn(用于HTTP请求)和Nginx(位于端口80/443前面并处理对前两个服务进行反向代理。这似乎很好用,我只能输入一个docker命令(带有docker stack deploy)。四个服务已连接并且可以相互通信。

但是当我拿起nginx容器并将其记录时,我只看到来自本地网络的请求:

10.255.0.2 - - [17/Jan/2019:13:01:59 +0000] "GET / HTTP/1.1" 200 930 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:6

4.0)Gecko / 20100101 Firefox / 64.0“”-“

此请求通过Internet发出,但是如您所见,显示了本地网络地址(10.255.0.2)。四个容器使用覆盖网络(恐怕有很多默认选项)。我找不到任何清楚的迹象说明发生这种情况的原因。我会在这里共享我的各种文件,但它们可能有点长。我们将妥协并共享docker-compose.yml文件。请注意,它仍然非常符合我的配置,并且无法立即使用,因为您很可能没有我指定的两个图像:

# docker-compose.yml
version: '3.7'

services:
  nginx:
    image: modified-nginx
    ports:
      - 80:80
      - 443:443
    depends_on:
      - gunicorn
      - daphne
    networks:
      - webnet
  gunicorn:
    image: website:0.0.8
    command: gunicorn website.wsgi:application --bind 0.0.0.0:8000
    volumes:
      - ./:/usr/src/app/
    environment:
      - SQL_ENGINE=django.db.backends.postgresql
      - SQL_DATABASE=postgres
      - SQL_HOST=db
      - SQL_PORT=5432
    depends_on:
      - db
    networks:
      - webnet
  daphne:
    image: website:0.0.8
    command: daphne --root-path=/usr/src/app/ -b 0.0.0.0 -p 9000 --proxy-headers website.asgi:application
    volumes:
      - ./:/usr/src/app/
    environment:
      - SQL_ENGINE=django.db.backends.postgresql
      - SQL_DATABASE=postgres
      - SQL_HOST=db
      - SQL_PORT=5432
    depends_on:
      - db
      - gunicorn
    networks:
      - webnet
  db:
    image: postgres:10.5-alpine
    volumes:
      - postgres_data:/var/lib/postgresql/data/
    networks:
      - webnet

networks:
  webnet:

volumes:
  postgres_data:

我认为此问题不是特定于Nginx容器的,它仍然很标准。我认为问题出在某个地方的Docker网络中,但是我不确定为什么,而且我不确定它总是那样。为此花了很多时间。

感谢任何指针,

Vincent

0 个答案:

没有答案