Ho il seguente docker-compose.yml
:Nginx Reverse Proxy non riuscendo con Linked Docker Contenitori
node1:
build: ./node
links:
- redis
ports:
- "8080"
node2:
build: ./node
links:
- redis
ports:
- "8080"
service1:
build: ./service
links:
- redis
ports:
- "8383"
redis:
image: redis
ports:
- "6379"
nginx:
build: ./nginx
links:
- node1:node1
- node2:node2
- service1:service1
ports:
- "80:80"
Dopo aver eseguito questa e funzionante docker ps
ottengo il seguente:
080d9d7dc2e0 dockerworkflow_nginx:latest "nginx -g 'daemon of 5 minutes ago Up 5 minutes 0.0.0.0:80->80/tcp, 443/tcp dockerworkflow_nginx_1
8c25bfdb9d00 dockerworkflow_node1:latest "nodemon /src/index. 6 minutes ago Up 6 minutes 0.0.0.0:33023->8080/tcp dockerworkflow_node1_1
4ae817be2a63 dockerworkflow_service1:latest "nodemon /src/index. 6 minutes ago Up 6 minutes 0.0.0.0:33022->8383/tcp dockerworkflow_service1_1
91ff238fe3f6 dockerworkflow_node2:latest "nodemon /src/index. 6 minutes ago Up 6 minutes 0.0.0.0:33021->8080/tcp dockerworkflow_node2_1
fe0c7e02c860 redis:latest "/entrypoint.sh redi 6 minutes ago Up 6 minutes 0.0.0.0:33020->6379/tcp dockerworkflow_redis_1
Tutto sembra essere bene finora.
Il nginx.conf
sto usando è simile al seguente:
worker_processes 4;
events { worker_connections 1024; }
http {
server {
listen 80;
location/{
proxy_pass http://node1;
}
location /a/ {
proxy_pass http://node2;
}
location /b/ {
proxy_pass http://service1;
}
}
}
Tutto questo in realtà dovrebbe essere fare è la seguente:
Se entro http://{host-ip}/
poi il contenitore node1
viene inoltrato la richiesta.
Se si immette http://{host-ip}/a/
, il contenitore node2
inoltra la richiesta.
Se si immette http://{host-ip}/b/
, il contenitore service1
inoltra la richiesta.
In questo momento, sto ricevendo 502 Bad Gateway
se provo qualcosa.
Per curiosità, il blocco a monte {} ha fatto qualcosa per risolvere il problema? O era solo un trailing/che l'ha risolto? – csgeek
nessuna gioia per me. cosa c'è nel tuo file proxy_params? – Adam