Несколько серверных блоков NGINX - 502 Bad Gateway - PullRequest
0 голосов
/ 19 сентября 2019

Я пытаюсь настроить несколько серверов, используя Nginx и Docker.Сейчас я хочу, чтобы это работало локально, но я экспортирую это, чтобы использовать на веб-сайте.Мой nginx.conf:

worker_processes 1;

events { worker_connections 1024; }

http {
    client_max_body_size 2048M;
    sendfile on;

    upstream docker-phpmyadmin {
        server phpmyadmin;
    }
    upstream docker-wordpress {
        server wordpress;
    }
    upstream docker-api {
        server api;
    }
    upstream docker-frontend {
        server frontend;
    }

    server {
        listen 80;
        server_name example.com;
        location / {
            proxy_set_header Host $http_host;
            proxy_pass http://docker-frontend;
        }
    }
    server {
        listen 80;
        server_name api.example.com;
        location / {
            proxy_set_header Host $http_host;
            proxy_pass http://docker-api;
        }
    }

    server {
        listen 80;
        server_name db.example.com;
        location / {
            proxy_set_header Host $http_host;
            proxy_pass http://docker-phpmyadmin;
        }
    }
    server {
        listen 80;
        server_name admin.example.com;
        location / {
            proxy_read_timeout 3600;
            proxy_set_header Host $http_host;
            proxy_pass http://docker-wordpress;
        }
    }
}

Я добавил эти записи в мой /etc/hosts:

127.0.0.1 example.com
127.0.0.1 db.example.com
127.0.0.1 api.example.com
127.0.0.1 admin.example.com

Мой docker-compose.yml содержит:

  nginx:
    build: ./backend/nginx
    links:
      - wordpress
      - phpmyadmin
      - frontend
    ports: 
      - ${NGINX_EXTERNAL_PORT}:80
    volumes:
      - "./backend/nginx/nginx.conf:/etc/nginx/nginx.conf"

Так, локально, NGINX_EXTERNAL_PORT установлен на 5000. Я могу получить доступ к db.example.com:5000 и admin.example.com:5000, но когда я пытаюсь получить доступ к моей главной странице example.com:5000, я получаю:

nginx_1       | 2019/09/18 21:26:52 [error] 6#6: *8 connect() failed (111: Connection refused) while connecting to upstream, client: 172.18.0.1, server: example.com, request: "GET / HTTP/1.1", upstream: "http://172.18.0.7:80/", host: "example.com:5000"
nginx_1       | 172.18.0.1 - - [18/Sep/2019:21:26:52 +0000] "GET / HTTP/1.1" 502 559 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.132 Safari/537.36"

Что-то не хватает в моей конфигурации для этого блока сервера?Спасибо!

1 Ответ

0 голосов
/ 19 сентября 2019

Оказалось, что это связано с тем, что приложение, находящееся в example.com, не открывало ни одного порта, поэтому после включения EXPOSE 3000 в Dockerfile и изменения восходящего потока на

upstream docker-frontend{
    server frontend:3000;
}

Работает!

...