记录docker swarm的使用

news2024/12/23 23:50:06
在前面的几篇文章中我们依次学习了dockerfile、docker-compose的使用,接下来是docker有一个比较
重要的使用,docker swarm的使用,与dockerfile和docker-compose相比较而言,docker swarm是在
多个服务器或主机上创建容器集群服务

准备

首先准备三台装好了docker的虚拟机:
dockerswarm1:192.168.47.251,作为manager节点
dockerswarm2:192.168.47.252,作为worker节点
dockerswarm3:192.168.47.253,作为worker节点
并且三台之间可以进行互相ping通。然后就可以开始启动docker swarm了,首先输入

docker node ls

返回结果:
在这里插入图片描述
表示没有swarm集群存在,且当前节点也不是管理节点。
那么我们就吧当前这个节点作为我们的管理节点,即192.168.47.251.
首先执行如下命令:

启动swarm

docker swarm init --advertise-addr 192.168.47.251

返回结果如图所示:
在这里插入图片描述
这里我们已经完成了manager的设置,从返回的提示都可以看出来,如果想要加入一个worker节点到当前的swarm,就执行如下命令:

docker swarm join --token SWMTKN-1-64211ybe5t29ia743mjc1q4vzw3hrsmlzqrbcrnr8djcwti0cw-asgkc27ezwlujmuudlv07txwj 192.168.47.251:2377

接着我们就在其他两个docker节点使用这个命令,加入到swarm集群中去:
如图所示,说明我们已经加入到swarm集群中去了:
在这里插入图片描述
然后我们在manager节点输入命令:

docker node ls

返回结果为如图所示:

在这里插入图片描述

使用docker swarm

接下来我们开始使用docker swarm,一般都是在manager上执行相关的docker swarm的命令,所以manger节点也是docker swarm的门户,基本上所有的命令都是从manager上执行的。
如图所示,是我在工作节点上执行命令的提示:
在这里插入图片描述

首先我们用docker拉取一个简单的镜像运行:

docker pull nginx:latest

接着创建一个私有网络,

docker network create -d overlay swarm_network

然后通过命令:

docker network ls

我们看到了我们创建的自定义网络:
在这里插入图片描述
接着我们就可以启动我们的nginx了

docker service create --replicas 1 --network swarm_network --name swarm_nginx -p 80:80 nginx:latest

如图所示,服务启动成功了:
在这里插入图片描述
此时我们设置的只有副本,所以检查的时候只有manager上有服务执行,现在我们进行扩容。

扩容swarm的服务

在这里插入图片描述
现在我们把副本扩容到了4个,经过manager的分配,我们发现在不同的节点上都有服务开始运行了。
dockerswarm1的manager上运行的服务:
在这里插入图片描述
在dockerswarm2上的worker上运行的服务:
在这里插入图片描述
在dockerswarm3上的worker上运行的服务:
在这里插入图片描述

docker service update --replicas 3 swarm_nginx

该命令也能达到和上面命令同样的效果

下线一个节点

docker node update --availability drain dockerswarm3

如图所示效果:
在这里插入图片描述
同时我们会发现刚刚在dockerswarm3上下线的服务,现在前部转移到了dockerswarm1和dockerswarm2上了:
在这里插入图片描述
在这里插入图片描述

激活一个下线中的服务

docker node update --availability active dockerswarm3

如图所示,已经激活了:
在这里插入图片描述

移除任务

把我们刚刚创建的swarm_nginx任务移除,如图所示:
执行命令:

docker service ps swarm_nginx

移除命令:

docker service rm swarm_nginx

在这里插入图片描述

删除节点

在对应的节点上执行如下命令:

docker swarm leave

在这里插入图片描述
在这里插入图片描述
当依次的把manager节点即,dockerswarm1删除时,整个集群就会自动删除。
在这里插入图片描述
docker swarm基本使用就这么多。后续我们会继续推出docker的比较理论化的东东。

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

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

相关文章

Leetcode——66. 加一

💯💯欢迎来到的热爱编程的小K的Leetcode的刷题专栏 文章目录 1、题目2、暴力模拟(自己的第一想法)3、官方题解 1、题目 给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。最高位数字存放在数组的首位, 数组…

CTF-PHP反序列化漏洞2-典型题目

作者:Eason_LYC 悲观者预言失败,十言九中。 乐观者创造奇迹,一次即可。 一个人的价值,在于他所拥有的。可以不学无术,但不能一无所有! 技术领域:WEB安全、网络攻防 关注WEB安全、网络攻防。我的…

【纯属娱乐】随机森林预测双色球

目录 一、数据标准化二、预测代码三、后续 一、数据标准化 首先,我们需要对原始数据进行处理,将其转换为可用于机器学习的格式。我们可以将开奖号码中的红球和蓝球分开,将其转换为独热编码,然后将其与期数一起作为特征输入到机器…

ETL工具 - Kettle 查询、连接、统计、脚本算子介绍

一、 Kettle 上篇文章对 Kettle 流程、应用算子进行了介绍,本篇对查询、连接、统计、脚本算子进行讲解,下面是上篇文章的地址: ETL工具 - Kettle 流程、应用算子介绍 二、查询算子 数据输入使用 MySQL 表输入,表结构如下&#x…

给httprunnermanager接口自动化测试平台换点颜色瞧瞧

文章目录 一、背景1.1、修改注册表单的提示颜色1.2、修改后台代码:注册错误提示,最后提交注册,密码校验;1.3、修改了注册,那登录呢,也不能放过二、总结 一、背景 虽然咱给HttpRunnerManger引入进来&#xf…

【云台】开源版本SimpleBGC的电机驱动与控制方式

前言 最近想学习一下云台,发现资料确实还不太好找,比较有参考价值的是俄版的开源版本的云台代码,后面就不开源了,开源版本的是比较原始的算法,差不多是玩具级别的,不过还是决定学习一下,了解一…

PyCaret:低代码自动化的机器学习工具

PyCaret简介 随着ChatGPT和AI画图的大火,机器学习作为实现人工智能的底层技术被大众越来越多的认知,基于机器学习的产品也越来越多。传统的机器学习实现方法需要较强的编程能力和数据科学基础,这使得想零基础尝试机器学习变得非常困难。 机器…

Ucore lab5

实验目的 了解第一个用户进程创建过程了解系统调用框架的实现机制了解ucore如何实现系统调用sys_fork/sys_exec/sys_exit/sys_wait来进行进程管理 实验内容 练习0:已有实验代码改进 ​本实验中完成了用户进程的创建,能够对用户进程进行基本管理,并为…

C语言入门篇——自定义数据篇

目录 1、结构体 1.2、匿名结构体 1.3、结构体的自引用 1.4、结构体的声明和初始化 1.5、结构体的内存对齐 1.6、修改默认对齐数 1.7、结构体传参 2、枚举 3、共用体(联合体) 1、结构体 设计程序时,最重要的步骤之一是选择表示数据的…

【微机原理】8088/8086微处理器

目录 一、8088/8086的功能结构 1.总线接口部件(BIU) 2.执行部件(EU) 二、8088/8086的寄存器结构(14个) 溢出标志的概念 溢出和进位的区别 8086CPU是Intel系列的16位微处理器,他有16根数据…

框架学习之KOCA框架简介

KOCA框架简介 什么是KOCA术语定义发展历史 KOCA的总体架构产品优势开放性敏捷性(一体化解决方案)融合性安全性接入网关- KOCA Gateway KOCA DevOps流水线 KOCA技术栈 金证开发者社区:http://koca.szkingdom.com/ 什么是KOCA KOCA是金证基于…

LC-1376. 通知所有员工所需的时间(DFS:自上而下、自下而上)

1376. 通知所有员工所需的时间 难度中等125 公司里有 n 名员工,每个员工的 ID 都是独一无二的,编号从 0 到 n - 1。公司的总负责人通过 headID 进行标识。 在 manager 数组中,每个员工都有一个直属负责人,其中 manager[i] 是第…

JavaScript常用数组方法-汇总

快速检索 方法解析 1:concat(); 功能:合并数组,可以合并一个或多个数组,会返回合并数组之后的数据,不会改变原来的数组; var str1 [12,2,"hello"];var str2 ["world"]; console.lo…

简单毛概刷题网页制作 2.0(拖欠近一年版)

原因是大概一年之前学校的毛概期末刷题网站突然崩了,但是一直没有修复。当时眼看着复习时间逐渐被压缩,自己啥也做不了,遂自学前端完成毛概刷题网页一枚。 最早的毛概刷题网站仅仅是 1.0 版本(传送门),功能…

Excel技能之对齐,你可能都没想到

Excel表格,既然要做得漂漂亮亮,一定离不开对齐。拍照需要美颜,表格需要对齐。 内容全部挤到一边去。 有些靠左,有些靠右。 加上空格,感觉对齐。如果数据特别多,又逃不过加班的命运。 实在是混乱不堪。审美…

Linux常用命令——iostat命令

在线Linux命令查询工具 iostat 监视系统输入输出设备和CPU的使用情况 补充说明 iostat命令被用于监视系统输入输出设备和CPU的使用情况。它的特点是汇报磁盘活动统计情况,同时也会汇报出CPU使用情况。同vmstat一样,iostat也有一个弱点,就…

Linux安装MongoDB数据库,并内网穿透远程连接

文章目录 前言1. 配置Mongodb源2. 安装MongoDB3. 局域网连接测试4. 安装cpolar内网穿透5. 配置公网访问地址6. 公网远程连接7. 固定连接公网地址8. 使用固定地址连接 转载自Cpolar Lisa文章:Linux服务器安装部署MongoDB数据库 - 无公网IP远程连接「内网穿透」 前言 …

Qt中QDebug的使用

QDebug类为调试信息(debugging information)提供输出流。它的声明在<QDebug>中&#xff0c;实现在Core模块中。将调试或跟踪信息(debugging or tracing information)写出到device, file, string or console时都会使用QDebug。 此类的成员函数参考&#xff1a;https://doc…

C语言—指针的进阶

指针的进阶 字符指针指针数组数组指针数组指针的定义区分&数组名以及数组名数组指针的使用 数组参数、指针参数一维数组传参二维数组传参一级指针传参二级指针传参 函数指针函数指针数组指向函数指针数组的指针回调函数指针和数组相关笔试题和面试题指针笔试题 指针的相关概…

C++ Boost.Reflection库(现在是Boost.PFR)的下载、安装、使用详细教程

这里写目录标题 一、Boost.Reflection简介二、Boost.Reflection&#xff08;现在是Boost.PFR&#xff09;库的下载和安装2.1、下载编译Boost2.2、使用Boost.Reflection&#xff08;现在是Boost.PFR&#xff09; 小结 一、Boost.Reflection简介 ​ Boost.Reflection&#xff0…