【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】

一.知识回顾

之前的内容都帮你整理好了,在这里哟!

【0.Docker相关目录文章整理,可自行查看,包含多节内容】
【1.Docker详细安装部署&阿里镜像地址配置】
【2.Docker架构&&架构角色概念&&角色作用】
【3.Docker命令详细讲解&实操演示】
【4.Docker镜像文件&加载原理&生产中重新制作并提交镜像文件&案例演示】
【5.Docker数据卷&数据卷容器&DockerFile执行流程】
【6.DockerFile构建自定义镜像实操&出现问题解决方案Failed to download metadata for repo ‘appstream‘: IPv4 forwarding disabled…】
【7.详细学习Docker部署搭建高可用的MySQL集群环境】
【8.基于haproxy实现负载均衡之~~~应用Docker部署搭建高可用的MySQL集群环境】
【9.Docker安装部署DockerCompose&案例演示&配置文件&命令实操学习】
【10.Docker部署私服仓库Harbor详细教程步骤&镜像拉取&推送到Harbor仓库实战演练应用】

二.Swarm部署

2.1 Swarm介绍

​ Swarm是Docker官方提供的一款集群管理工具,其主要作用是把若干台Docker主机抽象为一个整体,并且通过一个入口统一管理这些Docker主机上的各种Docker资源。Swarm和Kubernetes比较类似,但是更加轻,具有的功能也较kubernetes更少一些。

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第1张图片

2.1.1管理节点

管理节点处理集群管理任务:

  • 维护集群状态
  • 调度服务
  • 服务群模式HTTP API 端点

​ 使用Raft实现,管理器维护整个 swarm 及其上运行的所有服务的一致内部状态。出于测试目的,可以使用单个管理器运行 swarm。如果单管理器群中的管理器出现故障,您的服务会继续运行,但您需要创建一个新集群来恢复。

为了利用 swarm 模式的容错特性,Docker 建议您根据组织的高可用性要求实现奇数个节点。当您有多个管理器时,您可以在不停机的情况下从管理器节点的故障中恢复。

  • 三个管理器的群体最多可以容忍一个管理器的损失。
  • 一个五管理器群可以容忍最大同时丢失两个管理器节点。
  • 一个N管理器集群最多可以容忍管理器的丢失 (N-1)/2
  • Docker 建议一个群最多有七个管理器节点。
2.1.2工作节点

​ 工作节点也是 Docker 引擎的实例,其唯一目的是执行容器。Worker 节点不参与 Raft 分布式状态,不做出调度决策,也不为 swarm 模式 HTTP API 提供服务。

您可以创建一个由一个管理器节点组成的群,但是如果没有至少一个管理器节点,您就不能拥有一个工作节点。默认情况下,所有经理也是工人。在单个管理器节点集群中,您可以运行类似命令docker service create,调度程序将所有任务放在本地引擎上。

为防止调度程序将任务放置在多节点群中的管理器节点上,请将管理器节点的可用性设置为Drain。调度器在Drainmode 中优雅地停止节点上的任务并调度Active节点上的任务 。调度程序不会将新任务分配给具有Drain 可用性的节点。

2.2 Swarm集群搭建

2.2.1 环境准备

这个地方为了更方便的演示效果,我们就是docker官方提供给我们的Swarm演示网址。通过Dock Hub 的账号密码登录即可。没有账号的先去注册一下。但是需要注意的是在线演示网址会话时间为4个小时。

在线Swarm演示:点我即可

2.2.2 按照下面的要求一步一步来就可以

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第2张图片
【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第3张图片

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第4张图片

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第5张图片
【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第6张图片
【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第7张图片

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第8张图片

2.2.3 集群环境搭建
2.2.3.1 创建manager节点

注意:manager node也可以作为worker node提供服务

docker swarm init --advertise-addr 192.168.0.8

在这里插入图片描述

注意观察日志,拿到worker node加入manager node的信息

docker swarm join --token SWMTKN-1-4j5pbs0bwnwiy66m7b1xivzoc3lyanilxxepm64d83fled2mgb-62dsqcmdi0ca88g6djied9i0f 192.168.0.8:2377

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第9张图片

2.2.3.2 分别进入两个节点,执行如下的命令,使其成为Worker
docker swarm join --token SWMTKN-1-4j5pbs0bwnwiy66m7b1xivzoc3lyanilxxepm64d83fled2mgb-62dsqcmdi0ca88g6djied9i0f 192.168.0.8:2377

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第10张图片
【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第11张图片

2.2.3.3 进入manager node 查看集群情况
docker node ls

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第12张图片

2.2.3.4 node类型转换

可以将worker提升成manager,从而保证manager的高可用

docker node promote node2

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第13张图片

#降级可以用demote
docker node demote node2

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第14张图片

2.3 Raft一致性协议

2.3.1 Raft一致性协议:保证manager节点半数存活集群环境可用
2.3.2 管理节点

管理节点处理集群管理任务:

  • 维护集群状态
  • 调度服务
  • 服务群模式HTTP API 端点

​ 使用Raft实现,管理器维护整个 swarm 及其上运行的所有服务的一致内部状态。出于测试目的,可以使用单个管理器运行 swarm。如果单管理器群中的管理器出现故障,您的服务会继续运行,但您需要创建一个新集群来恢复。

为了利用 swarm 模式的容错特性,Docker 建议您根据组织的高可用性要求实现奇数个节点。当您有多个管理器时,您可以在不停机的情况下从管理器节点的故障中恢复。

  • 三个管理器的群体最多可以容忍一个管理器的损失。
  • 一个五管理器群可以容忍最大同时丢失两个管理器节点。
  • 一个N管理器集群最多可以容忍管理器的丢失 (N-1)/2
  • Docker 建议一个群最多有七个管理器节点。
2.3.3 工作节点

​ 工作节点也是 Docker 引擎的实例,其唯一目的是执行容器。Worker 节点不参与 Raft 分布式状态,不做出调度决策,也不为 swarm 模式 HTTP API 提供服务。

您可以创建一个由一个管理器节点组成的群,但是如果没有至少一个管理器节点,您就不能拥有一个工作节点。默认情况下,所有经理也是工人。在单个管理器节点集群中,您可以运行类似命令docker service create,调度程序将所有任务放在本地引擎上。

为防止调度程序将任务放置在多节点群中的管理器节点上,请将管理器节点的可用性设置为Drain。调度器在Drainmode 中优雅地停止节点上的任务并调度Active节点上的任务 。调度程序不会将新任务分配给具有Drain 可用性的节点。

2.4 Service

2.4.1 拉取tomcat镜像
docker pull tomcat

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第15张图片

2.4.2 创建一个tomcat的service
docker service create --name my-tomcat tomcat

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第16张图片

2.4.3 查看当前swarm的service
docker service ls

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第17张图片

2.4.4 查看service的启动日志
docker service logs my-tomcat

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第18张图片

2.4.5 查看service的详情
docker service inspect my-tomcat

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第19张图片

2.4.6 查看my-tomcat运行在哪个node上
docker service ps my-tomcat

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第20张图片

2.4.7 水平扩展service
docker service scale my-tomcat=3
docker service ls
docker service ps my-tomcat

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第21张图片

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第22张图片

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第23张图片
【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第24张图片

2.4.8 如果某个node上的my-tomcat挂掉了,这时候会自动扩展
[worker01-node]
docker rm -f containerid

[manager-node]
docker service ls
docker service ps my-tomcat
2.4.9 删除service
docker service rm my-tomcat

2.5 overlay网络

​ Overlay 在网络技术领域,指的是一种网络架构上叠加的虚拟化技术模式,其大体框架是对基础网络不进行大规模修改的条件下,实现应用在网络上的承载,并能与其它网络业务分离,并且以基于IP的基础网络技术为主。VXLAN(Virtual eXtensible LAN)技术是当前最为主流的Overlay标准

在这里插入图片描述

2.6 Docker结合Swarm部署WordPress实战

2.6.1 创建一个自定义overlay网卡
docker network create -d overlay my-overlay

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第25张图片

2.6.2 拉取mysql镜像&wordpress镜像

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第26张图片

2.6.3 创建MySQL service
docker service create --name mysql --mount type=volume,source=v1,destination=/var/lib/mysql --env MYSQL_ROOT_PASSWORD=examplepass --env MYSQL_DATABASE=db_wordpress --network my-overlay mysql:5.7

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第27张图片

2.6.4 建WordPress的Service
docker service create --name wordpress --env WORDPRESS_DB_USER=root --env WORDPRESS_DB_PASSWORD=examplepass --env WORDPRESS_DB_HOST=mysql:3306 --env WORDPRESS_DB_NAME=db_wordpress -p 8080:80 --network my-overlay wordpress

在这里插入图片描述

2.6.5 访问测试,三个节点都成功访问,完成。

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第28张图片

【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第29张图片
【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第30张图片
【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&overlay网络&Docker结合Swarm部署WordPress个人博客实战】_第31张图片

三个节点ip地址都不同,但是都能成功访问,原因就在于使用了overlay网卡。

好了,到这里【Docker之Swarm详细讲解&Swarm集群搭建&管理节点&工作节点&Raft一致性协议&Docker结合Swarm部署WordPress个人博客实战】。就结束了,更多内容持续学习创作中。

你可能感兴趣的:(Docker,Docker,Swarm集群搭建,Raft一致性协议工作管理节点,WordPress个人博客实战,overlay网络)