Docker nginx: [emerg] хост не найден в "обратном канале" - PullRequest
0 голосов
/ 04 ноября 2019

Я пытаюсь настроить флеш-сервер, используя uWSGI в сочетании с linuxserver / letsencrypt , используя docker-compose. Я использовал файл docker-compose.yml ниже с другим сервером nginx. Проблема в том, что контейнер nginx не может найти мой контейнер с колбой backend и поэтому не может выполнить с ним uwsgi_pass.

docker-compose.yml:

version: '3.1'
services:

    nginx:
      image: linuxserver/letsencrypt
      ports:
        - "80:80"
        - "443:443"
      volumes:
        - ./data/nginx/nginx.conf:/config/nginx/site-confs/default
        - ./data/nginx/uwsgi_params:/config/nginx/uwsgi_params
      depends_on:
        - backend
      networks:
        - backend
      container_name: nginx
      environment:
        - PUID=1000
        - PGID=1000
        - (+ other settings)


    backend:
        build: ./backend
        container_name: flask
        restart: always
        links:
            - db
        volumes:
            - ./backend:/app
            - ./managed:/managed
        expose: 
            - 8080

    db:
        image: mysql:5.7
        container_name: db
        restart: always
        ports:
            - "3306:3306"


volumes:
  flask-db:

networks:
  backend:

Я попытался соединить их, используя links, depends_on и networks, но, похоже, ничего не работает.

nginx.conf:

server {
    listen 80;
    server_name api.example.com;
    server_tokens off;

    location / {
        return 301 https://$host$request_uri;
    }
}

server {
    listen 443 ssl;
    server_name api.example.com;
    server_tokens off;

    location / {
        include uwsgi_params;
        uwsgi_pass backend:8080;
        proxy_set_header    Host                $http_host;
        proxy_set_header    X-Real-IP           $remote_addr;
        proxy_set_header    X-Forwarded-For     $proxy_add_x_forwarded_for;


        if ($request_method = 'POST') {
            add_header 'Access-Control-Allow-Origin' '*';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
            add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range';
            add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range';
        }
        if ($request_method = 'GET') {
            add_header 'Access-Control-Allow-Origin' '*';
            add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
            add_header 'Access-Control-Allow-Headers' 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range';
            add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range';
        }
    }
}

server {
    listen 80;
    server_name example.com;
    server_tokens off;

    location / {
        return 301 https://$host$request_uri;
    }
}

server {
    listen 443 ssl;
    server_name example.com;
    server_tokens off;

    location / {
        include uwsgi_params;
        uwsgi_pass backend:8080;
        proxy_set_header    Host                $http_host;
        proxy_set_header    X-Real-IP           $remote_addr;
        proxy_set_header    X-Forwarded-For     $proxy_add_x_forwarded_for;
    }
}

Ошибка в контейнере nginx:

nginx: [emerg] host not found in upstream "backend" in /config/nginx/site-confs/default:18

Следует также отметить, что том ./data/nginx/uwsgi_params простосписок команд uwsgi

Как мне сделать контейнер backend доступным из контейнера nginx?

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