如何在Debian 11上安装Docker Swarm集群
  d13fBrSsLBNG 2023年11月02日 54 0

Docker Swarm是一个用于管理 Docker 主机的工具。我们可以构建一个高可用性、高性能的Docker集群,其中应用部署在许多服务器上。

Docker swarm由管理主机和工作节点构建。您可以在Docker Swarm集群中拥有一个或多个管理器节点。管理器节点使用原生Docker API,并与工作节点共享Docker Swarm集群的数据库。管理主机维护集群状态、调度作业和处理HTTP API端点。

 如何在Debian 11上安装Docker Swarm集群_docker

与具有监控、Ingress和卷等全面功能的Kubernetes不同,Docker swarm的状态要简单得多。Docker Swarm还缺乏自动扩展功能,防护容器根据监控和资源使用情况进行扩展。必须手动缩放容器。

本文将引导您完成在Debian 11系统上安装Docker Swarm集群的过程。

1. 准备节点

配置 /etc/hosts 文件中每个节点的主机名以进行本地解析。

​sudo vim /etc/hosts​

添加每个服务器上节点的详细信息,包括管理器节点和工作器节点。

10.31.45.182  manager
10.31.45.226 worker-01
10.31.45.219 worker-02

确保主机可以通过 ping 相互联系

2. 在Debian 11上安装Docker CE

我们必须在所有主机、管理器和工作节点上安装Docker CE。

在主机上安装依赖包:

sudo apt-get update
sudo apt-get install apt-transport-https ca-certificates curl gnupg-agent software-properties-common

添加Docker GPG key:

curl -fsSL https://download.docker.com/linux/debian/gpg | sudo apt-key add -

添加Docker Repo

sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/debian $(lsb_release -cs) stable"

安装Docker引擎

sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli

启动并启用Docker

sudo systemctl start docker
sudo systemctl enable docker

添加用户至Docker群组

sudo usermod -aG docker ${USER}

3. 初始化Docker Swarm集群

在此步骤中,我们需要在管理器节点上初始化 Docker swarm模式,然后稍后可以添加工作节点。

以下命令用于初始化Docker Swarm管理器。您应该将地址替换为管理中心节点的 IP。

newgrp docker
sudo docker swarm init --advertise-addr <manager-IP>

输出样例:

$ docker swarm init --advertise-addr 10.31.45.182
Swarm initialized: current node (xj5sqdpsbs5x2pgt670dft31m) is now a manager.
To add a worker to this swarm, run the following command:
docker swarm join --token SWMTKN-1-5yat7zlum78qmnlhv1vs0b0k4c42jafh5kt8xtb36eara4c5ip-490dr4yhpbe5qnic476wh90zg 10.31.45.182:2377
To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.

初始化管理器节点后,我们现在可以使用上面示例中给出的联接令牌添加工作节点。

$ docker swarm join --token SWMTKN-1-5yat7zlum78qmnlhv1vs0b0k4c42jafh5kt8xtb36eara4c5ip-490dr4yhpbe5qnic476wh90zg 10.31.45.182:2377
This node joined a swarm as a worker.

我们可以使用以下命令检查工作节点是否已成功加入集群:

sudo docker node ls

输出样例:

$ docker node ls
ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION
h673oapwzqcsoszm36dcsyx4u worker-01 Ready Active 20.10.3
tg30e58pf2ebktyu5geg5hjzd worker-02 Ready Active 20.10.3
vhqes84cz4ljrrj8ux9bx9jzv worker-03 Ready Active 20.10.3
xj5sqdpsbs5x2pgt670dft31m * manager Ready Active Leader 20.10.3

部署应用于Docker Swarm

在这里,我们将在群集上部署一 Web应用程序。

$ docker service create --name webserver -p 8080:80 nginx

上述命令将 Nginx 应用程序部署在集群上,并在端口 8080 上公开。
要确认服务是否正在运行,请执行以下操作:

$ docker service ls
ID NAME MODE REPLICAS IMAGE PORTS
z383boupqk5p webserver replicated 1/1 nginx:latest *:80->80/tcp

在Docker Swarm上扩展应用程序

您可以在 Docker 群集群上扩展应用程序,以实现高可用性和高性能。
使用以下命令:

$ docker service scale webserver=4

其中 webserver=4 是应用程序的名称和复制后要启动的容器总数。

 如何在Debian 11上安装Docker Swarm集群_Docker_02

您可以使用以下命令验证副本:

docker service ls

运行命令后将会显示如以下信息:

 如何在Debian 11上安装Docker Swarm集群_docker_03

我们的 Docker Swarm 集群已成功部署在 Debian 11 主机上了。

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论

推荐阅读
  xqA0sOKuvLcb   2023年11月22日   16   0   0 redisDockerredisdocker
  bifOjSxj34Bv   2023年12月07日   21   0   0 nginxDockerdockernginx
  IEgV2R47Wr6T   2023年11月12日   51   0   0 数据mysqldocker