This is diagram is used to deploy the 3 nodes Docker swarm.
data:image/s3,"s3://crabby-images/15512/15512305966048bd4e612290df549844888b529b" alt=""
On three nodes: docker01, docker02, and docker03.
apt-get update
data:image/s3,"s3://crabby-images/83da5/83da5b336fae1aa462ab18154ef0944346469abc" alt=""
Install Docker CE on Debian 10.
apt-get install apt-transport-https ca-certificates curl gnupg-agent software-properties-common
Add Docker GPG key and Docker repository.
curl -fsSL https://download.docker.com/linux/debian/gpg | apt-key add -
add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/debian $(lsb_release -cs) stable"
data:image/s3,"s3://crabby-images/29d9e/29d9e15fb57949697913a4c2494a656a0e90c7da" alt=""
Install Docker Engine
apt-get update
apt-get install docker-ce docker-ce-cli
data:image/s3,"s3://crabby-images/ee6e4/ee6e48d65dddc85fd5ec010e99a56885ffb1bec1" alt=""
Enable and start Docker daemon.
systemctl start docker
systemctl enable docker
data:image/s3,"s3://crabby-images/b3b6e/b3b6e56e7d74a76f647d21fb9b03bbc556c78ec9" alt=""
+ Initialize Docker Swarm Cluster on node 1: docker01
docker swarm init --advertise-addr 192.168.5.46
data:image/s3,"s3://crabby-images/480f5/480f513cbef0966c3d4a16851356eb6c0068b015" alt=""
Join docker02 and docker03 to the cluster.
data:image/s3,"s3://crabby-images/baf8b/baf8b208dd8d122a99928a8148836f26fd7e17b9" alt=""
data:image/s3,"s3://crabby-images/07e19/07e19d6a282a812bd88f49a7c4f8336d581b3043" alt=""
Create a custom httpd image with the listening port is 8847.
data:image/s3,"s3://crabby-images/0fb56/0fb564525440959b4aab84d3fbb618a1e60533f0" alt=""
We can check if the worker nodes have joined to cluster successfully using the command below:
docker node ls
+ Deploy Applications on Docker Swarm
Below is an example to deploy an Apache web service with the listening port is 8847 and service name is tunghttp
docker service create --name tunghttp -p 8847:80 httpd
data:image/s3,"s3://crabby-images/b142a/b142a6bdf002aa93ac8f7e021b98f54a6ece70e0" alt=""
+ Scale Applications on Docker Swarm to have high availability and high performance on 3 nodes.
docker service scale tunghttp=3
docker service ps tunghttp
data:image/s3,"s3://crabby-images/b7efc/b7efc995ac11b65414c1c549a05d17c1a8ed9378" alt=""
data:image/s3,"s3://crabby-images/e899c/e899c2c7fa079c209f3aaddde8b0d9d29bbc9cef" alt=""
Create a new index.html file on the docker host. Then, copy the file to the Apache webserver directory as a screenshot below.
<html>
<head>
<title>Tung A01</title>
</head>
<body>
<h1 Welcome to the web server that is deployed by Docker </h1>
<img src="http://imagefromtheinternet.jpg">
</body>
</html>
data:image/s3,"s3://crabby-images/d22cf/d22cf4f0faf9b4d1031440ef685119833e9125c1" alt=""
data:image/s3,"s3://crabby-images/7e272/7e272e388cf86658032fce5218e53b375e2f9883" alt=""
Open the web browser and access the web server via port 8847 on three Docker IP addresses.
data:image/s3,"s3://crabby-images/d78fe/d78fe4c54590ff7c67d5168d3d26740209d335ea" alt=""
data:image/s3,"s3://crabby-images/05bc3/05bc3772c3921c2874219f515ef60f28178d2121" alt=""
data:image/s3,"s3://crabby-images/39548/39548c29778907af1257ccf00061c5c34bd8f7d9" alt=""
Check three nodes.
docker node ls
data:image/s3,"s3://crabby-images/b7b02/b7b02e7112143d0a22a41fc9b5be2e93a766aa61" alt=""
Check the 8847 port is running on the Docker node.
netstat -ant | grep 8847
data:image/s3,"s3://crabby-images/17bed/17bedbffa9df259d5a28ac4b3191e8b8ecf05007" alt=""