Docker Swarm*
This sample deployment demonstrates the use of Docker* in swarm mode. The following conditions apply:
- All images are built and tested with
docker compose
. To learn more about building the images withdocker compose
, refer to Express Setup. - Push images to the registry to make them available for deployment on other systems.
- Run the commands below from the
open-amt-cloud-toolkit
install directory.
Important
Not for production use.
Get the Toolkit¶
-
Open a Terminal or Command Prompt and navigate to a directory of your choice for development:
git clone --recursive https://github.com/open-amt-cloud-toolkit/open-amt-cloud-toolkit --branch v2.14.0
-
Change to the cloned
open-amt-cloud-toolkit
directory.cd open-amt-cloud-toolkit
Deploy the stack to the swarm¶
Important - For Linux
Before running the following commands on Linux, confirm that the user has been added to the docker group. For instructions, refer to Add docker group. Otherwise, prefix each command with sudo
.
-
Initialize a swarm.
docker swarm init
-
Copy docker compose config to temporary
swarm.yml
file.docker compose -f .\docker-compose.yml config > swarm.yml
-
Set the network driver to overlay in the
swarm.yml
file.sed -i "s|driver: bridge|driver: overlay|g" swarm.yml
(Get-Content -Path './swarm.yml') -replace 'driver: bridge', 'driver: overlay' | Set-Content -Path './swarm.yml'
Important
Open the swarm.yml file to check that
driver: bridge
was replaced withdriver: overlay
. If the result is incorrect or corrupted, delete the swarm.yml file, rerun Step 2, and manually replace the string. -
If you've run
docker compose
previously, as in the instructions in Express Setup, rundocker compose down
to stop the open-amt-cloud-toolkit services:docker compose down -v
-
Create the stack.
docker stack deploy -c swarm.yml scalingdemo
-
Check all of the services are running.
docker stack services scalingdemo
Success
The table below is an example of a services list:
ID NAME MODE REPLICAS IMAGE PORTS 6dye78yg66zp scalingdemo_db replicated 1/1 postgres:latest *:5432->5432/tcp nahbub6fxrvu scalingdemo_kong replicated 1/1 kong:2.3 :443->8443/tcp, :8001->8001/tcp nltp54asb8kz scalingdemo_mps replicated 1/1 mps:latest *:4433->4433/tcp uc9jsf5554cv scalingdemo_mpsrouter replicated 1/1 mpsrouter:latest ojtcs8qjxct3 scalingdemo_rps replicated 1/1 rps:latest wbk4of70do63 scalingdemo_vault replicated 1/1 vault:latest *:8200->8200/tcp pc143h8ml4ua scalingdemo_webui replicated 1/1 webui:latest -
Scale the mps service.
docker service scale scalingdemo_mps=2
Success
The table below is an example of a services list after scaling the mps:
ID NAME MODE REPLICAS IMAGE PORTS 6dye78yg66zp scalingdemo_db replicated 1/1 postgres:latest *:5432->5432/tcp nahbub6fxrvu scalingdemo_kong replicated 1/1 kong:2.3 :443->8443/tcp, :8001->8001/tcp nltp54asb8kz scalingdemo_mps replicated 2/2 mps:latest *:4433->4433/tcp uc9jsf5554cv scalingdemo_mpsrouter replicated 1/1 mpsrouter:latest ojtcs8qjxct3 scalingdemo_rps replicated 1/1 rps:latest wbk4of70do63 scalingdemo_vault replicated 1/1 vault:latest *:8200->8200/tcp pc143h8ml4ua scalingdemo_webui replicated 1/1 webui:latest -
Remove the stack:
docker stack rm scalingdemo