Docker六脉神剑 (五) Docker Swarm集群搭建及基础服务部署

简介: Docker六脉神剑 (五) Docker Swarm集群搭建及基础服务部署

集群是什么?

集群(cluster)技术是一种较新的技术,通过集群技术,可以在付出较低成本的情况下获得在性能、可靠性、灵活性方面的相对较高的收益,其任务调度则是集群系统中的核心技术。

集群是一组相互独立的、通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理。一个客户与集群相互作用时,集群像是一个独立的服务器。集群配置是用于提高可用性和可缩放性。

例如:小饭店原来只有一个厨师,切菜洗菜备料炒菜全干。后来客人多了,厨房一个厨师忙不过来,又请了个厨师,两个厨师都能炒一样的菜,这两个厨师的关系是集群。

为了让厨师专心炒菜,把菜做到极致,又请了个配菜师负责切菜,备菜,备料,厨师和配菜师的关系是分布式,一个配菜师也忙不过来了,又请了个配菜师,两个配菜师关系是集群

分布式及优点:

分布式是将一个应用程序拆分成多个模块来工作,这些模块所负责的功能部分都不相同,并且缺一不可。它存在的主要作用是大幅度的提高工作效率,缓解服务器的访问和存储压力。这么做的优点是它非常细节的划分出了应用程序的各个功能板块,避免了把一个完整的应用程序全部都给到一台服务器去工作的损耗。从一个应用程序分配到多个服务器上,大大的使每台不同的服务器都尽到职责。

集群及优点:

而集群则是将一个应用程序集中到多个服务器上,每一台做的都是相同的事情,但是它和分布式不同的是,缺一台,其他的服务器还可以补位。集群的优点就是当其中的一个服务器宕机了,其他相同的服务器可以代替其继续工作;将应用程序部署在多台服务器时,也提供了数据的吞吐量。

它们二者明显的区别有两个点:

第一:虽然表面上看服务器的数量是一样的,可是分布式是每台的任务都不同,而集群则是相同的。

第二:分布式中的服务器少一台可能会丢失功能且不能运行,但是集群少一台依旧可以正常工作。

首先, 玩docker里面的集群要对docker有一定了解。docker集群有两种 docker swarmdocker Kubernetes

swarm是官方提供的集群,Kubernetes是谷歌提供的。两个集群都是非常不错的, 我们这边先介绍swarm,随后再写关于Kubernetes的文章

Swarm环境搭建

环境提要

节点全部使用ubuntu 18.04 server版, 这边准备了两个node节点和一个master节点

  • IP:192.168.1.17 主机名:master17 担任角色:swarm manager
  • IP:192.168.1.15 主机名:node15 担任角色:swarm node
  • IP:192.168.1.16 主机名:node16 担任角色:swarm node

然后每个主机之间都能相互ping通, 每个节点都安装了docker

  • ubuntu安装
sudo apt install docker.io

初始化集群

  • master17
sudo docker swarm init --advertise-addr 192.168.1.17
# 出现如下信息
Swarm initialized: current node (0zzr236y761v6ojezxtndavft) is now a manager.
# 这里是跟你说 如何添加一个work节点
To add a worker to this swarm, run the following command:
docker swarm join --token SWMTKN-1-5ytayrb0qmb010qnmz9ws6s9dpvpkez1rmov6xjeskcj0gw39q-5rr7x8ryzcbdc7tvxs0t9q11x 192.168.1.17:2377
# 如何添加manager节点
To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.
# 查看节点。 这样就可以看到我们的master节点了
sudo docker node ls

上面命令执行后,该机器自动加入到swarm集群。这个会创建一个集群token,获取全球唯一的 token,作为集群唯一标识。后续将其他节点加入集群都会用到这个token值。

其中,--advertise-addr参数表示其它swarm中的worker节点使用此ip地址与manager联系。命令的输出包含了其它节点如何加入集群的命令。

将node节点加入集群

  • node15 、 node16
# 加入集群成为work节点
sudo docker swarm join --token SWMTKN-1-5ytayrb0qmb010qnmz9ws6s9dpvpkez1rmov6xjeskcj0gw39q-5rr7x8ryzcbdc7tvxs0t9q11x 192.168.1.17:2377

然后到master节点上面去查看集群节点

集群常用命令

  • sudo docker swarm leave 离开集群, 如果是master节点加上--force参数
  • sudo docker node 查看集群节点
  • sudo docker swarm init 初始化集群  --advertise-addr 192.168.1.17加上这个参数可以绑定ip

集群已经准备好了, 接下来就要将我们的服务部署到集群上面

nginx服务部署+服务伸缩

需要创建服务, 调度集群等都需要到master节点上操作。

创建nginx服务 并且将端口映射

sudo docker service create --replicas 3 -p 80:80 --name nginx nginx:1.13.7-alpine
# 该docker service create命令创建服务。
# 该--name标志为服务命名nginx。
# 该--replicas标志指定3个运行实例的所需状态。
# 参数nginx:1.13.7-alpine 是以这个镜像来创建服务

现在我们使用浏览器,输入任意节点 IP ,即可看到 nginx 默认页面。

查看服务

# 查看所有服务
sudo docker service ls
# 查看服务信息
sudo docker service inspect nginx
# 查看哪些节点正在运行服务
sudo docker service ps nginx
# 同时 也可以看见在本机上的容器
sudo docker ps
# 查看服务标准输出日志
sudo docker service logs nginx

服务伸缩

我们可以使用 docker service scale 对一个服务运行的容器数量进行伸缩。当业务处于高峰期时,我们需要扩展服务运行的容器数量。当业务平稳时,我们需要减少服务运行的容器数量。

# 指定伸缩数量
sudo docker service scale nginx=5
  • 删除服务
sudo docker service rm nginx

服务滚动升级

我们基于nginx:1.13.7-alpine镜像部署了一个名为 nginx 的服务。

现在我们想要将 NGINX 版本升级到 1.13.12,那么在 Swarm mode 中如何升级服务呢?

你可能会想到,先停止原来的服务,再使用新镜像部署一个服务,不就完成服务的 “升级” 了吗。

这样做的弊端很明显,如果新部署的服务出现问题,原来的服务删除之后,很难恢复,那么在 Swarm mode 中到底该如何对服务进行滚动升级呢?

答案就是使用 docker service update 命令。

  • 服务升级
docker service update --image nginx:1.13.12-alpine nginx

以上命令使用 --image 选项更新了服务的镜像。当然我们也可以使用 docker service update 更新任意的配置。

  • 服务回退

现在假设我们发现 nginx 服务的镜像升级到 nginx:1.13.12-alpine 出现了一些问题,我们可以使用命令一键回退。

docker service rollback nginx

结束语

本篇属于对刚了解集群的做了个基础讲解,那么博主还会出一篇使用swarm部署lnmp应用的文章,正常我们部署集群肯定不是使用命令部署,我们都是声明式的, 所以它会和compose一样, 编写yml配置。这里还要对刚刚玩swarm的新手说一下,网上很多教程都是使用docker-machine + virtualbox快速搭建集群, 但其实都是一样, 但是这种搭建集群的方式很快速, 适合玩过集群的人, 希望小伙伴们还是手动实践, 毕竟集群还是比较重要的知识点

博主保证, 文章中设计的东西都是亲自尝试过的, 所以大家可以去试试, 不会浪费大家时间的, 有疑问可以评论, 看到一定会及时回复的。

目录
打赏
0
0
0
0
340
分享
相关文章
Docker部署RocketMQ5.2.0集群
本文详细介绍了如何使用Docker和Docker Compose部署RocketMQ 5.2.0集群。通过创建配置文件、启动集群和验证容器状态,您可以快速搭建起一个RocketMQ集群环境。希望本文能够帮助您更好地理解和应用RocketMQ,提高消息中间件的部署和管理效率。
371 91
|
20天前
|
Ubuntu下部署及操作Docker技巧
以上就是在Ubuntu下部署及操作Docker的具体步骤。但这只是冰山一角,Docker的魅力远不仅如此。你可以将其视为存放各种工具的小箱子,随时随地取用,极大地提升工作效率。你也可以私人订制,适应不同的开发环境,就像一个拥有各种口味冰淇淋的冰箱,满足各种各样的需求。好了,现在你已经掌握了基本的Docker运用技巧,快去尝试使用吧!记住,沉浸在探索中,你会找到无尽的乐趣和满满的收获。
84 23
Docker 部署 Redis
在使用 Docker 部署 Redis 时,为实现数据持久化,需正确挂载容器内的数据目录到宿主机。推荐命令如下: ``` docker run -d --name redis -v /mnt/data/redis:/data -p 6379:6379 redis ``` 该命令将宿主机的 `/mnt/data/redis` 目录挂载到容器的 `/data` 目录,确保 Redis 数据持久化。此路径更通用,适合大多数场景。避免使用不匹配的挂载路径,如 `/var/lib/redis` 或 `/mnt/data/redis` 到非默认目录,以防止数据无法正确持久化。
大模型文件Docker镜像化部署技术详解
大模型文件Docker镜像化部署技术详解
202 2
美团面试:MySQL为什么 不用 Docker部署?
45岁老架构师尼恩在读者交流群中分享了关于“MySQL为什么不推荐使用Docker部署”的深入分析。通过系统化的梳理,尼恩帮助读者理解为何大型MySQL数据库通常不使用Docker部署,主要涉及性能、管理复杂度和稳定性等方面的考量。文章详细解释了有状态容器的特点、Docker的资源隔离问题以及磁盘IO性能损耗,并提供了小型MySQL使用Docker的最佳实践。此外,尼恩还介绍了Share Nothing架构的优势及其应用场景,强调了配置管理和数据持久化的挑战。最后,尼恩建议读者参考《尼恩Java面试宝典PDF》以提升技术能力,更好地应对面试中的难题。
|
1月前
|
在Docker上部署Ollama+AnythingLLM完成本地LLM Agent部署
通过以上步骤,您可以成功在Docker上部署Ollama和AnythingLLM,实现本地LLM Agent的功能。在部署过程中,确保环境和配置正确,以避免不必要的问题。希望本文能够帮助您顺利完成部署,并在本地环境中高效地使用LLM模型。
672 8
Stirling-PDF:51.4K Star!用Docker部署私有PDF工作站,支持50多种PDF操作,从此告别在线工具
Stirling-PDF 是一款基于 Docker 的本地化 PDF 编辑工具,支持 50 多种 PDF 操作,包括合并、拆分、转换、压缩等,同时提供多语言支持和企业级功能,满足个人和企业用户的多样化需求。
159 6
Stirling-PDF:51.4K Star!用Docker部署私有PDF工作站,支持50多种PDF操作,从此告别在线工具
如何通过pm2以cluster模式多进程部署next.js(包括docker下的部署)
通过这些步骤,可以确保您的Next.js应用在多核服务器上高效运行,并且在Docker环境中实现高效的容器化管理。
290 44
docker快速部署OS web中间件 数据库 编程应用
通过Docker,可以轻松地部署操作系统、Web中间件、数据库和编程应用。本文详细介绍了使用Docker部署这些组件的基本步骤和命令,展示了如何通过Docker Compose编排多容器应用。希望本文能帮助开发者更高效地使用Docker进行应用部署和管理。
84 19
Docker——阿里云服务器使用Docker部署python项目全程小记
本文记录了我在阿里云服务器上使用Docker部署python项目(flask为例)的全过程,在这里记录和分享一下,希望可以给大家提供一些参考。
182 1
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等