I have the following docker-compose.yml
:
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"
After executing this and running docker ps
I get the following:
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
Everything seems to be good so far.
The nginx.conf
I am using looks like the following:
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;
}
}
}
All this should really be doing is the following:
If I enter http://{host-ip}/
then the node1
container is forwarded the request.
If I enter http://{host-ip}/a/
then the node2
container is forwarded the request.
If I enter http://{host-ip}/b/
then the service1
container is forwarded the request.
Right now, I am getting 502 Bad Gateway
if I try anything.
I was able to figure out the solution and it turned out to be something stupid that didn't show up in any logs and was difficult for me to come across.
Below is the updated nginx.conf
file.
worker_processes 4;
events { worker_connections 1024; }
http {
upstream node_app {
server node1:8080;
}
upstream service_app {
server service1:8383;
}
server {
listen 80;
location / {
proxy_pass http://node_app/;
include /etc/nginx/proxy_params;
}
location /a/ {
proxy_pass http://node_app/;
include /etc/nginx/proxy_params;
}
location /b/ {
proxy_pass http://service_app/;
include /etc/nginx/proxy_params;
}
}
}
Not sure if the include is necessary at this point, but the trailing /
at the end of the proxy_pass
directive seem to do the trick at the end of the day.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With