This post will show you how to setup a Swarm Cluster, deploy a couple of microservices, and create a Reverse Proxy Service (with Traefik) in charge of routing requests on their base URLs.
data:image/s3,"s3://crabby-images/167ff/167ffa205d5e2d0e5c4daaa6e34876df8c75c10c" alt=""
If you haven’t already, create a Swarm cluster, you could use the shell script below to setup a cluster with 3 nodes (1 Manager & 2 Workers)
1 | #!/bin/sh |
Issue the following command to execute the script:
1 | chmod +x setup.sh |
The output of the above command is as follows:
data:image/s3,"s3://crabby-images/7d149/7d149194299c7c5219cafa2c6a87c3f47d2c99fc" alt=""
At this moment, we have 3 nodes:
data:image/s3,"s3://crabby-images/509e7/509e70bd04672f6b323243c3735a682833eb7883" alt=""
Our example microservice application consists of two parts. The Books API and the Movies API. For both parts I have prepared images for you that can be pulled from the DockerHub.
The Dockerfiles for both images can be found on my Github.
Create docker-compose.yml file with the following content:
1 | version: "3.3" |
- We use an overlay network named traefik-net, on which we add the services we want to expose to Traefik.
- We use constraints to deploy the APIs on workers & Traefik on Swarm manager.
- Traefik container is configured to listen on port 80 for the standard HTTP traffic, but also exposes port 8080 for a web dashboard.
- The use of docker socket (/var/run/docker.sock) allows Traefik to listen to Docker Daemon events, and reconfigure itself when containers are started/stopped.
- The label traefik.frontend.rule is used by Træfik to determine which container to use for which Request Path.
- The configs part create a configuration file for Traefik from config.toml (it enables the Docker backend)
1 | logLevel="DEBUG" |
In order to deploy our stack, we should execute the following command:
1 | docker stack deploy --compose-file docker-compose.yml api |
Let’s check the overlay network:
1 | docker network ls |
data:image/s3,"s3://crabby-images/1e7f7/1e7f759db643e0aa344f9e6d8717346ea2350863" alt=""
Traefik configuration:
1 | docker config ls |
data:image/s3,"s3://crabby-images/ac40b/ac40b3c2562c195b8e61018ace86994aec1450ea" alt=""
To display the configuration content:
1 | docker config inspect api_traefik-config --pretty |
data:image/s3,"s3://crabby-images/96a2e/96a2e80de504e9c9cb378afd3a61ee83a3c1efbe" alt=""
And finally, to list all the services:
1 | docker stack ps api |
data:image/s3,"s3://crabby-images/fd91c/fd91ca0cd9b3740c79bb05e8e1dccf1cf87e40ed" alt=""
In the list of above, you can see that the 3 containers are being running on node-1, node-2 & node-3 :
data:image/s3,"s3://crabby-images/2cdc2/2cdc2fc9cd2ce5a7efb10a9fbc1843503fdbf2ea" alt=""
If you point your favorite browser (not you IE 😂) to the Traefik Dashboard URL (http://MANAGER_NODE_IP:8080) you should see that the frontends and backends are well defined:
data:image/s3,"s3://crabby-images/267aa/267aab6ee822a92ddd55f52a327553083332507e" alt=""
If you check http://MANAGER_NODE_IP/books, you will get a list of books
data:image/s3,"s3://crabby-images/91554/91554dccd7353614290343c5f120b9fe5ba75cc1" alt=""
If you replace the base URL with /movies:
data:image/s3,"s3://crabby-images/5f99c/5f99c10fbfa2f27cc5cf50f6cd93f9be17663ae8" alt=""
What happens if we want to scale out the books & movies APIs. With the docker service scale command:
data:image/s3,"s3://crabby-images/b1572/b15723a60c3ee1d396e3476277669327ccd43aa4" alt=""
data:image/s3,"s3://crabby-images/1a361/1a3612d9df752e0c08f9cb0bdc6fc923a689f1ab" alt=""
We can confirm that:
data:image/s3,"s3://crabby-images/e8954/e8954ce7e0c17854305bc8e80f6604ad583d7fa3" alt=""
Obviously Traefik did recognise that we started more containers and made them available to the right frontend automatically:
data:image/s3,"s3://crabby-images/a0ad6/a0ad651cb68353193c79b2726739e90f07bf801c" alt=""
In the diagram below, you will find that the manager has decied to schedule the new containers on node-2 (3 of them) and node-3 (4 of them) using the Round Robin strategy
data:image/s3,"s3://crabby-images/c5bdd/c5bdd83227a5ca88dd615623c946c97fd74d61f7" alt=""
Drop your comments, feedback, or suggestions below — or connect with me directly on Twitter @mlabouardy.