如何在Debian 11上安装Docker Swarm集群
nanshan 2024-10-09 12:51 8 浏览 0 评论
Docker Swarm是一个用于管理 Docker 主机的工具。我们可以构建一个高可用性、高性能的Docker集群,其中应用部署在许多服务器上。
Docker swarm由管理主机和工作节点构建。您可以在Docker Swarm集群中拥有一个或多个管理器节点。管理器节点使用原生Docker API,并与工作节点共享Docker Swarm集群的数据库。管理主机维护集群状态、调度作业和处理HTTP API端点。
与具有监控、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 是应用程序的名称和复制后要启动的容器总数。
您可以使用以下命令验证副本:
docker service ls
运行命令后将会显示如以下信息:
我们的 Docker Swarm 集群已成功部署在 Debian 11 主机上了。yyds!
相关推荐
- 【华纳云】用Ubuntu镜像配置防火墙保护VPS服务器,保姆式教学
-
保姆式教学:如何用Ubuntu22.04镜像配置UFW防火墙保护VPS服务器?今天讲使用UFW配置防火墙来保护服务器。UFW是uncomplicatedfirewall的简称,是IPtables的...
- 网络&多任务 day03-网络编程基础-IP地址查看
-
目标知道使用ifconfig命令可以查询主机的IP地址知道使用ping命令可以查看网络的连通性#1.虚拟机网卡设置NAT(网络地址转换模式):则虚拟机会使用主机VMnet8这块虚拟网卡与...
- 怎么把旧电脑改私有云,如何把旧电脑改私有云?
-
随着科技的飞速发展,许多人家中都有了闲置的旧电脑。这些电脑虽然性能不再顶尖,但仍具备相当的存储和计算能力。将它们改造成私有云,不仅可以实现资源的再利用,还能为家庭或小型团队提供一个安全、便捷的数据存储...
- 多功能开源终端Wave Terminal安装与远程连接内网Linux服务器教程
-
前言本文主要介绍一款多功能高颜值的跨平台开源终端WaveTerminal在Windows电脑上如何安装,并结合cpolar内网穿透工具轻松实现跨网络远程连接本地内网Linux服务器,无需公网IP。作...
- ip地址管理之phpIPAM保姆级安装教程 (原创)
-
本教程基于Ubuntu24.04LTS,安装phpIPAM(最新稳定版1.7),使用Apache、PHP8.3和MariaDB,遵循最佳实践,确保安全性和稳定性。一、环境准备1....
- ubuntu安装Paperless-ngx强大的文档管理工具并实现远程使用
-
前言在当今快节奏的办公环境中,文档管理成为了一个不可忽视的问题。想象一下这样的场景:你需要一份重要的合同,却在堆积如山的文件中迷失了方向。你手忙脚乱地翻找,汗水顺着额头滴落,心里默念:“快出现吧,合同...
- ubuntu服务器运维
-
1.安装上传下载命令:直接执行命令就可以:sudoaptupdatesudoaptinstalllrzsz-y然后就能看到执行过程了2.安装mysql安装MySQLServersudo...
- 搭建nginx反向代理用作内网域名转发
-
情景由于公司内网有多台服务器的http服务要映射到公司外网静态IP,如果用路由的端口映射来做,就只能一台内网服务器的80端口映射到外网80端口,其他服务器的80端口只能映射到外网的非80端口。非80端...
- VMware Workstation环境下DNS的安装配置,并使用ubuntu来测试
-
需求说明:某企业信息中心计划使用IP地址17216.11.0用于虚拟网络测试,注册域名为xyz.net.cn.并将172.16.11.2作为主域名的服务器(DNS服务器)的IP地址,将172.16.1...
- 如何在Linux中配置网络连接和设置静态IP地址?
-
#挑战30天在头条写日记#在Linux中配置网络连接并设置静态IP地址需要执行以下步骤和具体细节数据。请注意,以下步骤适用于基于Debian的Linux发行版(如Ubuntu),在其他发行版中略有不同...
- Linux设置静态IP
-
测试服务器OS:Centos6.5x64本机OS:Ubuntu14.04x64由于Virtualbox当时安装Centos6.5的时候设置的是自动获取的IP,所以局域网内每次启动,IP有...
- 在不同Linux发行版中,如何静态IP地址?本文值得收藏!
-
想象一下,你的Linux服务器正在运行一个关键服务,比如Web服务器或文件共享平台,突然因为IP地址变更,外部设备无法连接,服务中断。这种情况在动态IP分配(DHCP)环境下并不少见。静态IP地址就像...
- ubuntu 22.04配置固定IP
-
vi/etc/netplan/00-installer-config.yaml保存网卡配置:netplanapply##如果有报错请检查00-installer-config.yaml网卡关...
- Ubuntu操作系统如何修改DNS
-
Ubuntu操作系统下有时难免需要进行DNS的修改,修改DNS的目的可以让你的上网速度有所提升。或者软件下载速度提升。下面介绍如何在ubunru系统修改对应的DNS方法一:使用gedit编辑器进行DN...
- VMWare虚拟机下为Ubuntu 12.04.1配置静态IP(NAT方式)
-
背景在虚拟机下运行操作系统,尤其是Linux系统已经是非常常见的做法。有时你想在虚拟机下搭建一个(模拟)服务器来供主机访问,比如搭建一个telnet/ssh。此时你会发现,每次启动虚拟机,VMWare...
你 发表评论:
欢迎- 一周热门
-
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
[常用工具] OpenCV_contrib库在windows下编译使用指南
-
WindowsServer2022|配置NTP服务器的命令
-
Ubuntu系统Daphne + Nginx + supervisor部署Django项目
-
WIN11 安装配置 linux 子系统 Ubuntu 图形界面 桌面系统
-
解决Linux终端中“-bash: nano: command not found”问题
-
Linux 中的文件描述符是什么?(linux 打开文件表 文件描述符)
-
NBA 2K25虚拟内存不足/爆内存/内存占用100% 一文速解
-
K3s禁用Service Load Balancer,解决获取浏览器IP不正确问题
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)