Nginx работает вне Docker, но не внутри - PullRequest
0 голосов
/ 09 сентября 2018

Я создаю персональный сайт, используя Django, Gunicorn, Nginx и Docker. Когда я выполню:

gunicorn --chdir personal-website --bind :8000 personal_website.wsgi:application

Вывод:

[arturocuya@localhost personalwebsite]$ gunicorn --chdir personal-website --bind :8000 personal_website.wsgi:application
[2018-09-09 11:49:02 -0500] [5161] [INFO] Starting gunicorn 19.6.0
[2018-09-09 11:49:02 -0500] [5161] [INFO] Listening at: http://0.0.0.0:8000 (5161)
[2018-09-09 11:49:02 -0500] [5161] [INFO] Using worker: sync
[2018-09-09 11:49:02 -0500] [5165] [INFO] Booting worker with pid: 5165

И это работает (вроде, настройка статических файлов еще не завершена)

Проблема в том, что когда я запускаю контейнер Docker с sudo docker-compose up, я получаю 502 Bad Gateway

Я подозреваю, что проблема в том, как я использую порты, но я не совсем понимаю, как это должно быть сделано.

Это моя структура папок

.
├── config
│   └── nginx
│       └── conf.d
│           └── local.conf
├── docker-compose.yml
├── Dockerfile
└── personal-website
    └── manage.py

Dockerfile

# Start from an official image
FROM python:3.6

# The following is an arbitrary location choice
RUN mkdir -p /opt/services/personalwebsite/src
WORKDIR /opt/services/personalwebsite/src

# Copy the project code
COPY . /opt/services/personalwebsite/src

# Install dependencies
RUN pip install django gunicorn Pillow

# Expose Port 8000
EXPOSE 8000

# Define the default command to run when starting the container
CMD ["gunicorn", "--chdir", "personal-website", "--bind", ":8000", "personal_website.wsgi:application"]

докер-compose.yml

version: '3'

services:
  personalwebsite:
    build: .
    volumes:
      - .:/opt/services/personalwebsite/src
    networks:
     - nginx_network

  nginx:
    image: nginx:1.13
    ports:
      - 8000:80
    volumes:
      - ./config/nginx/conf.d:/etc/nginx/conf.d
    depends_on:
      - personalwebsite

    networks:
      - nginx_network

networks:
  nginx_network:
    driver: bridge

config / nginx / conf.d / local.conf

# first we declare our upstream server, which is our Gunicorn application
upstream personalwebsite_server {
    # docker will automatically resolve this to the correct address
    # because we use the same name as the service: "personalwebsite"
    server personalwebsite:8000;
}

# now we declare our main server
server {

    listen 80;
    server_name localhost;

    location / {
        # everything is passed to Gunicorn
        proxy_pass http://personalwebsite;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $host;
        proxy_redirect off;
    }
}

Я также удостоверился, что изменил ALLOWED_HOSTS внутри проекта Django settings.py

ALLOWED_HOSTS = ['127.0.0.1', '149.248.5.164', '0.0.0.0']

Редактировать 1: Как кто-то предложил в комментариях, я получил доступ к контейнеру Nginx с помощью sudo docker-compose exec nginx bash, а затем сделал curl personalwebsite:8000. Я получил ошибку DISALLOWED HOST, поэтому я добавил personalwebsite к разрешенным хостам в settings.py, затем я попытался снова свернуться, и на выходе был HTML-код моей страницы, что нормально.

Это, похоже, помогло внутри контейнера, потому что выводом был HTML-код моей страницы. Но потом я сделал sudo docker-compose up и снова получил 502 Bad Gateway. Точный результат был:

[arturocuya@localhost personalwebsite]$ sudo docker-compose up
[sudo] password for arturocuya: 
Starting personalwebsite_personalwebsite_1 ... done
Starting personalwebsite_nginx_1           ... done
Attaching to personalwebsite_personalwebsite_1, personalwebsite_nginx_1
personalwebsite_1  | [2018-09-10 02:07:12 +0000] [1] [INFO] Starting gunicorn 19.9.0
personalwebsite_1  | [2018-09-10 02:07:12 +0000] [1] [INFO] Listening at: http://0.0.0.0:8000 (1)
personalwebsite_1  | [2018-09-10 02:07:12 +0000] [1] [INFO] Using worker: sync
personalwebsite_1  | [2018-09-10 02:07:12 +0000] [10] [INFO] Booting worker with pid: 10
nginx_1            | 172.26.0.1 - - [10/Sep/2018:02:07:17 +0000] "GET / HTTP/1.1" 502 576 "-" "Mozilla/5.0 (X11; Fedora; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.79 Safari/537.36" "-"
nginx_1            | 2018/09/10 02:07:17 [error] 8#8: *1 connect() failed (111: Connection refused) while connecting to upstream, client: 172.26.0.1, server: localhost, request: "GET / HTTP/1.1", upstream: "http://172.26.0.2:80/", host: "0.0.0.0:8000"
nginx_1            | 2018/09/10 02:07:18 [error] 8#8: *1 connect() failed (111: Connection refused) while connecting to upstream, client: 172.26.0.1, server: localhost, request: "GET /favicon.ico HTTP/1.1", upstream: "http://172.26.0.2:80/favicon.ico", host: "0.0.0.0:8000", referrer: "http://0.0.0.0:8000/"
nginx_1            | 172.26.0.1 - - [10/Sep/2018:02:07:18 +0000] "GET /favicon.ico HTTP/1.1" 502 576 "http://0.0.0.0:8000/" "Mozilla/5.0 (X11; Fedora; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.79 Safari/537.36" "-"

Ответы [ 2 ]

0 голосов
/ 10 сентября 2018

Это очень легко понять, ваш proxy_pass URL и upstream ключевое слово должны совпадать

Для глубокого погружения в верхнюю конфигурацию Nginx перейдите по ссылке

0 голосов
/ 10 сентября 2018

Ваша конфигурация Nginx должна быть

upstream personalwebsite {
    server personalwebsite:8000;
}

# now we declare our main server
server {

    listen 80;
    server_name localhost;

    location / {
        # everything is passed to Gunicorn
        proxy_pass http://personalwebsite;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $host;
        proxy_redirect off;
    }
}

Служба Nginx работает внутри контейнера?

Пожалуйста, нажмите на команду ниже в контейнере Nginx и дайте мне знать результат

curl -I localhost:80
...