微服务实战系列之玩转Docker(十二)

news2024/9/20 14:59:02

前言

山一程,水一程,身向榆关那畔行,夜深千帐灯。——清·纳兰性德

最近偶读纳兰的《长相思》经典之作,被这个“行军”场面震撼了。长长的队伍,跋山涉水,野宿一处。夜深人静的时候,突然激发了纳兰的“思乡”之情,他的留恋和伤感从此被永远定格。可见,如想看懂一个人,可以从他的文章入手,慢慢研读,细细品味。

闲言少叙,言归正传。通过本系列第十篇和第十一篇的分享,Docker Swarm的面纱已经被博主揭开一多半了,但是还差一截不是么?接下来,博主继续分享Swarm集群的实践,教你掌握多Manager节点的集群部署,以真正实现高可用

Q:如何管理Swarm cluster(进阶)

通过前序文章,我们可以轻松的Build一套单一manager的swarm集群。但是缺陷很明显,不足以满足高可用的目标。所以本博的目的是部署一套多manager的swarm集群

1. 资源准备

根据RAFT协议,我们设置manager节点3个,worker节点3个。

序号节点名称节点类型
1docker-manager1(10.11.12.70)manager
2docker-manager2(10.11.12.64)manager
3docker-manager3(10.11.12.66)manager
4docker-worker1(10.11.12.73)worker
5docker-worker2(10.11.12.74)worker
6docker-worker3(10.11.12.65)worker

参考下图部署架构,博主计划部署一个多manager节点的swarm集群:
在这里插入图片描述

2. 部署要求

根据资源清单,提供了3个manager和3个worker,我们可以这样完成集群定义:
在这里插入图片描述

提示:在同一个swarm集群中,每个worker node只从属于一个manager node。

3. 创建集群

3.1 Manager组群

首先我们把3个manager拉入一个群中,可按如下步骤完成。

3.1.1 新建Leader

俗话说,“火车跑得快,全凭车头带”。同理,Swarm集群也需要一个带头“大哥”,我们让docker-manager1节点当大哥吧。依然通过docker swarm init来完成:

docker swarm init --advertise-addr 10.11.12.70

结果为:
在这里插入图片描述
在这里插入图片描述

通过上图,我们新建了一个swarm集群并指定Leader,该集群支持以managerworker身份加入。这里我们选择manager,即:add a manager to this swarm.

3.1.2 组建Manager group

选择以manager身份加入swarm集群,需要按如下步骤完成。
Step1
获取入群的token,通过docker swarm join-token manager执行:
在这里插入图片描述
此时,你获得了一个加入群的口令,即docker swarm join...
Step2
docker-manager2docker-manager3节点中,分别执行返回的口令完成入群:

docker swarm join --token SWMTKN-1-3lpswen1fo9ju11j5xd6tledniqj5veqbtgypm1j9wh2xp0aot-91oghmtrip7g1hyzrxcoj6t3o 10.11.12.70:2377

那么结果为:
在这里插入图片描述
在这里插入图片描述
最后在docker-manager1leader)节点,我们可以看到manager group建立起来了:
在这里插入图片描述

提示:docker swarm join-token命令只能在manager节点中运行.

3.2 Manager与Worker组群

完成了3.1系列操作,我们接着为每个manager指定worker。博主以docker-manager1为例,其他manager皆重复一遍。

在docker-manager1节点中,执行docker swarm join-token worker
在这里插入图片描述
返回一个docker swarm join ...,该命令支持以worker身份加入集群,并指定manager节点。那么我们可以直接copy后,在docker-worker1节点执行:
在这里插入图片描述
此时,集群包含了3个manager node和1个worker node:
在这里插入图片描述

同样,根据部署要求,docker-manager2docker-manager3均指定相应的worker后,我们可以看到最终的集群如下:

在这里插入图片描述

提示:有些同学有疑问,为什么docker-worker2的状态有Ready和Down?这是因为worker2节点中途退出了集群,然后又加入了集群。

4. 情景演练

很简单,比如可以按如下几种展开:

  • docker-manager1节点down了,观察集群的变化
  • docker-worker1节点down了,观察集群的变化
  • 3个manager节点均down了,观察集群的变化

结语

通过本文,博主对多manager多worker集群进行了完整的演示,相信各位对Swarm集群有了更多的认识。当然swarm还有其他更高阶的用法,期待未来有更多分享!


系列回顾


微服务实战系列之玩转Docker(十一)
微服务实战系列之玩转Docker(十)
微服务实战系列之玩转Docker(九)
微服务实战系列之玩转Docker(八)
微服务实战系列之玩转Docker(七)
微服务实战系列之玩转Docker(六)
微服务实战系列之玩转Docker(五)
微服务实战系列之玩转Docker(四)
微服务实战系列之玩转Docker(三)
微服务实战系列之玩转Docker(二)
微服务实战系列之玩转Docker(一)
微服务实战系列之云原生

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2069507.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CSS3页面布局-三栏-固定宽度布局

布局的基本概念 多栏布局三种基本实现方案:固定宽度,流动,弹性。 固定宽度布局:大小不会随用户调整浏览器窗口大小。 一版960-1100,960常见,可以被3,4,5,6,8,10,12,16整除。 流动布局:大小会随用户调整…

芯片要火不要“热”!仿真技术助力芯片热设计

芯片散热仿真好比一场微观世界里的“清凉大作战”! 想象一下,小小的芯片就像迷你城市,无数的电子如同居民在其中穿梭。当芯片高速运转,就像城市进入了狂欢,热闹非凡但也会产生大量的热量。 而芯片散热仿真用数字和算法…

OpenStack前置配置与安装

环境:CentOS8最小化安装 九大组件: Nova:提供计算资源,cpu、内存等 Glance:提供镜像(查找)能力,真正存放镜像的是后端Swift。 Swift:对象存储,可以用来存放镜像。还可以用来存储备份。 Cin…

java生成黄红封面

import java.awt.*; import java.awt.geom.Rectangle2D; import java.awt.image.BufferedImage; import java.io.File; import javax.imageio.ImageIO;public class CoverGenerator {public static void generateCover(String name, String outputPath) {// A4纸的分辨率 (300 …

POJO、PO、DTO、VO、BO到底是什么?都如何使用?(基础概念+传输示意图+示例代码)带你一次玩转层出不穷的Object

文章目录 前言一、解释关系二、POJO、PO、DTO、VO、DAO、BO1.什么是POJO(Plain Old Java Object)2.什么是PO(Persistent Object)3.什么是DTO(Data Transfer Object)4.什么是VO(View Object&…

缓冲区

原理 #include <stdio.h> #include <string.h> int main() { const char *msg0"hello printf\n"; const char *msg1"hello fwrite\n"; const char *msg2"hello write\n"; printf("%s", msg0); fwrite(msg1, strlen(msg0)…

MySQL 数据页详解

数据页是MySQL 中定义的的一个存储结构 数据页是保存数据行的容器 页的16KB的大小是MySQL的⼀个默认设置&#xff0c;可以适用于⼤多数场景&#xff0c;当然也可以根据自己的实际业务场景进行修改页的大小&#xff0c;通过系统变量 innodb_page_size 进行调整与查看&#xff…

可计量Agilent N5181A详情资料keysight N5182A模拟信号发生器

Keysight N5181A&#xff08;Agilent&#xff09;MXG RF 模拟信号发生器的功能和规格包括&#xff1a;信号特性&#xff1a; 100 kHz 至 1、3 或 6 GHz 1 GHz 时输出功率为 23 dBm -121 dBc/Hz&#xff08;典型值&#xff09;相位噪声&#xff08;1 GHz 和 20 kHz 偏移&…

程序员常用的十个PyCharm插件,学会工作都不用加班了!

安装方法 先来说说插件的安装方法&#xff0c;一点都不难。 选择顶部菜单栏的 PyCharm 选项&#xff0c;打开 Preferences &#xff0c;点击 plugins &#xff0c;在右侧的文本框中输入想要查看的插件名称&#xff0c;在下方就会罗列出已经安装的相关的插件。 找到我们所需要的…

虹猫ai推文软件官方

虹猫AI推文软件是一款由虹猫小队开发的人工智能推文工具。该软件通过训练深度学习模型&#xff0c;能够自动生成优质的推文内容&#xff0c;帮助用户快速撰写出吸引人的推文。 虹猫ai推文软件官方https://iimenvrieak.feishu.cn/docx/O0UedptjbonN4UxyEy7cPlZknYc 虹猫AI推文软…

在Windows下安装设置VirtualBox

文章目录 一、下载VirtualBox二、安装VirtualBox三、安装虚拟机 一、下载VirtualBox 下载地址 直链下载 二、安装VirtualBox 打开下载好的安装包&#xff0c;点击下一步 根据自己的需求选择安装功能&#xff0c;之后选择安装目录&#xff0c;完成后下一步 提前注意是否有…

棚子影院CMS程序PHP源码

01, 棚子影视是我现在最常用的一个看视频的网站&#xff0c;支持观看电影、国漫&#xff01;动漫&#xff0c;电视剧、综艺、记录片、香港剧等等。同时棚子影视支持手机&#xff0c;PC端在线观看&#xff0c;不用下载任何播放器&#xff0c;直接电脑或者手机打开网址就可以在线…

自动化脚本到LabVIEW转换

工业自动化领域中的专用脚本语言转换为LabVIEW时需要注意的问题 语法差异&#xff1a; 脚本语言特点&#xff1a; 工业自动化脚本语言通常具有特定的语法和结构&#xff0c;例如条件判断、循环控制、硬件指令等。这些语言直接面向硬件操作&#xff0c;语法简洁&#xff0c;适用…

Python编码系列—Python单元测试的艺术:深入探索unittest与pytest

&#x1f31f;&#x1f31f; 欢迎来到我的技术小筑&#xff0c;一个专为技术探索者打造的交流空间。在这里&#xff0c;我们不仅分享代码的智慧&#xff0c;还探讨技术的深度与广度。无论您是资深开发者还是技术新手&#xff0c;这里都有一片属于您的天空。让我们在知识的海洋中…

[数据集][目标检测]考场行为作弊检测数据集VOC+YOLO格式4413张4类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;4413 标注数量(xml文件个数)&#xff1a;4413 标注数量(txt文件个数)&#xff1a;4413 标注…

LeetCode33

445.两数相加Ⅱ 给你两个 非空 链表来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储一位数字。将这两数相加会返回一个新的链表。 你可以假设除了数字 0 之外&#xff0c;这两个数字都不会以零开头。 示例1&#xff1a; 输入&#xff1a;l1 [7,2,4,3…

SD Maid SE v1.2.3 — 老牌清理工具全面升级,更简洁,更流畅了

SD Maid&#xff08;SD女佣&#xff09;是一款老牌的安卓垃圾清理神器&#xff0c;支持手机文件概览、文件搜索、应用管理、卸载残留、系统清理、应用清理、重复文件以及存储分析等多种实用功能。近期推出的SD Maid SE采用了全新的架构和技术&#xff0c;全面兼容最新的安卓版本…

如何高效利用ChatGPT撰写论文:从初稿到终稿的全程精华指南

在近年来的人工智能快速发展中&#xff0c;自然语言处理领域尤其显著&#xff0c;其中ChatGPT作为OpenAI推出的先进语言模型&#xff0c;不仅在日常交互上表现出众&#xff0c;其在专业写作方面也展现了巨大潜力。本文将详尽介绍如何高效地利用ChatGPT来撰写和修改学术论文&…

【Linux篇】Linux命令基础

目录 1. Linux的目录结构 1.1 Linux的目录结构 1.2 /在Linux系统中的表示 2. linux命令基础 2.1 什么是命令和命令行 2.2 Linux命令的通用格式 2.3 ls命令 2.3.1 ls命令的参数的作用&#xff1a; 2.3.2 ls命令的选项 2.3.3 命令的选项组合使用 2.4 cd切换工作目录 2…

YOLOv8多种方法改进CBAM注意力机制有效提升检测精度(已跑通)

一、CBAM概念 CBAM&#xff08;Convolutional Block Attention Module&#xff09;是一种用于卷积神经网络&#xff08;CNN&#xff09;的注意力机制&#xff0c;旨在提高网络的表现能力。它通过引入两个注意力模块来增强特征图的表达能力。 二、源码&#xff1a; class Chan…