Сетевой IP со стеком докера - PullRequest
0 голосов
/ 17 января 2019

Мне наконец-то удалось создать работающую конфигурацию 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 "" - "

Этот запрос поступил через Интернет, но, как вы можете видеть, был отображен адрес локальной сети (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 где-то, но я не уверен, почему, и я не уверен, что так было всегда. На это потребовалось немало попыток.

Спасибо за любые указатели,

Винсент

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...