web-dev-qa-db-fra.com

docker-compose pour nginx et serveur nodejs

J'ai ce qui suit docker-compose.yml fichier:

version: '3'
services:
    server:
        build:
            context: ../../
            dockerfile: ./packages/website/Dockerfile
        command: node /cutting/index.js
        environment:
            PORT: 8000
            NODE_ENV: production
        restart: always
    nginx:
        build:
            context: ./
            dockerfile: ./nginx/Dockerfile
        command: tail -f /dev/null
        depends_on:
            - server
        ports:
            - "8000:8000"
        restart: always

Et ce qui suit nginx.conf:

worker_processes 1;

user nobody nogroup;
pid /tmp/nginx.pid;
error_log /tmp/logs/nginx.error.log;

events {
    worker_connections 1024;
    accept_mutex off;
}

http {
    include mime.types;
    default_type application/octet-stream;
    access_log /tmp/logs/nginx.access.log combined;
    sendfile on;

    server {
        proxy_http_version 1.1; # this is essential for chunked responses to work

        listen   80; ## listen for ipv4; this line is default and implied
        listen   [::]:80 default ipv6only=on; ## listen for ipv6
        client_max_body_size 4G;
        server_name frontend;

        gzip on;
        gzip_disable "msie6";
        gzip_vary on;
        gzip_proxied any;
        gzip_comp_level 6;
        gzip_buffers 16 8k;
        gzip_http_version 1.1;
        gzip_types application/javascript text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;

        keepalive_timeout 5;

        location /static/  {
            alias /static/;
        }

        location  / {
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Host $http_Host;

            # UNCOMMENT LINE BELOW IF THIS IS BEHIND A SSL PROXY
            #proxy_set_header X-Forwarded-Proto https;

            proxy_redirect off;
            proxy_pass   http://localhost:8000;
        }
    }
}

Si cela crée 2 conteneurs, comment puis-je obtenir nginx pour voir le localhost: 8000 sur l'autre conteneur?

8
dagda1

Vous utilisez le name du conteneur tel que vous l'avez défini dans docker-compose.yml. Docker fournit les adresses IP des conteneurs nommés via DNS dans chaque conteneur et les met à jour si les conteneurs sont mis à jour.

Dans ce cas, vous l'avez appelé server, c'est donc ce que vous utiliseriez.

    proxy_pass http://server:8000;

Documentation: Mise en réseau dans Compose

13
Michael Hampton

Dans ce cas, vous devez utiliser en amont comme:

upstream backend {
    server express-server:81; #you container/service name
}

puis utilisez:

proxy_pass http://backend
0
Nitin Prajapati