Load Balancing Containers

we'll explore how you can use the NGINX web server to load balance requests between two containers running on the host.

Step 1:-NGINX Proxy

 ​Nginx-proxy accepts HTTP requests and proxies the request to the appropriate container based on the request Hostname. This is transparent to the user with happens without any additional performance overhead.

 

In this scenario, we want to have a NGINX service running which can dynamically discovery and update its load balance configuration when new containers are loaded.

Use the command below to launch nginx-proxy.

docker run -d -p 80:80 -e DEFAULT_HOST=proxy.example -v /var/run/docker.sock:/tmp/docker.sock:ro --name nginx jwilder/nginx-proxy

DEFAULTHOST: we can set an optional _-e DEFAULTHOST=<domain>. If a request comes in and doesn't make any specified hosts, then this is the container where the request will be handled. This enables you to run multiple websites with different domains on a single machine with a fall-back to a known website

Sock: This is a connection to the Docker daemon running on the host and allows containers to access its metadata via the API. Nginx-proxy uses this to listen for events and then updates the NGINX configuration based on the container IP address. Mounting file works in the same way as directories using -v /var/run/docker.sock:/tmp/docker.sock:ro. We specify :ro to restrict access to read-only.

Lunch Your App Container with below command

 

docker run -d -p 80 -e VIRTUAL_HOST=servicediscovery.com

Like and Subscribe My Product Engineer Channel.
Thank you so much

Load Balancer with Docker Containers

By Sagar Mal Shankhala

Load Balancer with Docker Containers

  • 566