Docker Tutorials

How to Create a Docker Swarm with Ubuntu 22.04

Learn how to create a Docker Swarm with Ubuntu 22.04: step-by-step guide to set up and manage a powerful container orchestration solution.



In the world of containerization and orchestration, Docker Swarm has emerged as a powerful tool for managing containerized applications. By creating a Docker Swarm, you can deploy and scale your applications seamlessly across a cluster of machines. This guide will walk you through the process of creating a Docker Swarm with Ubuntu 22.04, enabling you to harness the full potential of containerization.

Prerequisites for Running Docker Swarm

Before you can start setting up and running Docker Swarm, there are a few prerequisites that you need to fulfill. These prerequisites ensure a smooth installation and operation of Docker Swarm. Here are the prerequisites for running Docker Swarm with Ubuntu 22.04:

  1. Operating System: Docker Swarm is compatible with various operating systems, including Linux, Windows, and macOS. However, for this guide, we will focus on Ubuntu 22.04 as the operating system of choice. Make sure you have Ubuntu 22.04 installed on the machines that will be part of your Docker Swarm.
  2. Hardware Requirements: Docker Swarm requires a cluster of machines to function as nodes. These machines should meet the minimum hardware requirements to run Docker and handle containerized applications efficiently. Ensure that each machine in your cluster has sufficient CPU, memory, and disk space resources.
  3. Networking: Docker Swarm relies on networking to enable communication between nodes and services. You need to ensure that your nodes are connected to a network and have proper network configuration. Additionally, you may need to configure firewalls or security groups to allow the necessary network traffic for Docker Swarm. Make sure that the network connectivity between the nodes is established and reliable.
  4. Docker Engine: Before setting up Docker Swarm, you must have Docker Engine installed on each machine that will be part of the swarm. Docker Engine is responsible for running and managing containers. Install Docker Engine on all the nodes by following the official Docker installation instructions for Ubuntu 22.04.
  5. Container Images: To deploy services using Docker Swarm, you will need the container images of your applications. These images can be built using Dockerfiles or pulled from a container registry. Make sure you have the necessary Docker images prepared for the services you plan to deploy on the swarm. You can build custom images or use pre-existing images from trusted sources.
  6. Access and Permissions: Setting up and managing a Docker Swarm requires administrative or root access to the machines. Ensure that you have the necessary access and permissions on each node to perform the required configurations and operations. This includes the ability to install packages, modify system settings, and execute Docker commands.

By fulfilling these prerequisites, you will be ready to proceed with the installation and setup of Docker Swarm on Ubuntu 22.04. It’s essential to have a solid foundation in place to ensure a successful and efficient deployment of your containerized applications using Docker Swarm.

How to Create a Docker Swarm with Ubuntu 22.04

Docker Swarm is a native clustering and orchestration solution provided by Docker. It allows you to create and manage a swarm of Docker nodes, forming a single virtual Docker host. To create a Docker Swarm with Ubuntu 22.04, follow these steps:

Step 1: Install Docker on Ubuntu 22.04

Before creating a Docker Swarm, you need to have Docker installed on your Ubuntu 22.04 machine. Docker provides a convenient script for installing Docker Engine on Ubuntu. Open a terminal and run the following command:

$ curl -fsSL -o
$ sudo sh

This command will download and execute the Docker installation script. Once the installation is complete, you can verify the Docker version by running:

$ docker version

Step 2: Initialize the Docker Swarm

To create a Docker Swarm, you need to initialize it on the manager node. The manager node acts as the control plane for the Docker Swarm. Open a terminal and run the following command to initialize the Docker Swarm:

$ docker swarm init --advertise-addr <manager-node-ip>

Replace <manager-node-ip> with the IP address of your manager node. This command will output a token that you will need to join worker nodes to the swarm.

Step 3: Join Worker Nodes to the Swarm

Once the Docker Swarm is initialized, you can join worker nodes to the swarm. Worker nodes are the machines that will run your containerized applications. To join a worker node to the swarm, open a terminal on the worker node and run the following command:

$ docker swarm join --token <worker-token> <manager-node-ip>:<manager-port>

Replace <worker-token> with the token generated during the swarm initialization, and <manager-node-ip>:<manager-port> with the IP address and port of the manager node.

Step 4: Deploy Services to the Swarm

With the worker nodes joined to the swarm, you can now deploy services on the Docker Swarm. Services in Docker Swarm are long-running tasks that can be replicated across the swarm. To deploy a service, run the following command:

$ docker service create --name <service-name> <image>

Replace <service-name> with the desired name for your service, and <image> with the Docker image you want to deploy.

Frequently Asked Questions (FAQs)

How do I check the status of my Docker Swarm?

To check the status of your Docker Swarm, you can use the following command on the manager node:

$ docker node ls

This command will display the list of nodes in the swarm and their status.

Can I add more worker nodes to an existing Docker Swarm?

Yes, you can add more worker nodes to an existing Docker Swarm. To join a new worker node to the swarm, follow the instructions in Step 3.

How can I scale a service in a Docker Swarm?

Scaling a service in a Docker Swarm is straightforward. You can use the following command to scale a service:

$ docker service scale <service-name>=<replicas>

Replace <service-name> with the name of your service and <replicas> with the desired number of replicas.

Is it possible to deploy a service on a specific node in the swarm?

Yes, Docker Swarm provides placement constraints that allow you to deploy a service on a specific node or set of nodes. You can use the --constraint flag when creating a service to specify the constraints.

Can I update a service in a Docker Swarm without downtime?

Yes, Docker Swarm supports rolling updates, allowing you to update a service without causing downtime. You can use the docker service update command to update a service with new configurations or a new image.

How can I remove a Docker Swarm?

To remove a Docker Swarm, you can run the following command on the manager node:

$ docker swarm leave --force

This command will make the manager node leave the swarm and remove the swarm.


Creating a Docker Swarm with Ubuntu 22.04 allows you to harness the power of containerization and orchestration for deploying and scaling your applications. By following the steps outlined in this guide, you can easily set up a Docker Swarm and start managing your containerized services effectively. With Docker Swarm, you can achieve high availability, scalability, and fault tolerance for your applications.

author avatar
Patrick Domingues

Leave a Comment

Stay Informed

Receive instant notifications when new content is released.