docker哪个版本内置swarm

2022年7月14日 52点热度 0人点赞

从“docker 1.12.0”版本开始内置swarm;swarm是用于管理docker集群的平台,采用go语言完成的开发,从“1.12.0”版本开始,“Docker Swarm”已经包含在Docker引擎中,并且已经内置了服务发现工具,因此不需要再配置Etcd或者Consul来进行服务发现配置。

docker哪个版本内置swarm插图

本教程操作环境:linux7.3系统、docker19.03版、Dell G3电脑。

docker哪个版本内置swarm

Swarm 是 Docker 公司推出的用来管理 docker 集群的平台,几乎全部用 GO 语言来完成的开发的

Docker Swarm 和 Docker Compose 一样,都是 Docker 官方容器编排项目,但不同的是,Docker Compose 是一个在单个服务器或主机上创建多个容器的工具,而 Docker Swarm 则可以在多个服务器或主机上创建容器集群服务,对于微服务的部署,显然 Docker Swarm 会更加适合。

从 Docker 1.12.0 版本开始,Docker Swarm 已经包含在 Docker 引擎中(docker swarm),并且已经内置了服务发现工具,我们就不需要像之前一样,再配置 Etcd 或者 Consul 来进行服务发现配置了。

15.png

上图可以看出,Swarm 是典型的 master-slave 结构,通过发现服务来选举 manager。manager 是中心管理节点,各个 node 上运行 agent 接受 manager 的统一管理,集群会自动通过 Raft 协议分布式选举出 manager 节点,无需额外的发现服务支持,避免了单点的瓶颈问题,同时也内置了 DNS 的负载均衡和对外部负载均衡机制的集成支持。

扩展知识

Docker Swarm 工作原理

1)Docker Engine client

docker service create:我们通过 docker service create 这个命令去创建一个服务。

2)swarm manager

API:这个请求直接由Swarm manager的API进行接收,接收命令并创建服务对象。

orchestrator:为服务创建一个任务。

allocater:为这个任务分配IP地址。

dispatcher:将任务分配到指定的节点。

scheduler:再该节点中下发指定命令。

3)worker node:接收manager任务后去运行这个任务

container:创建相应的容器。

worker:连接到调度程序以检查分配的任务

executor:执行分配给工作节点的任务

Service:为一个副本,可以理解为是一个任务,一个任务是一个容器。

swarm manager:它将这个副本下发到三个可用的work节点。

container:实际的docker容器去运行应用。

task:work任务的名称为service名称后面跟.1根据个数以此类推。

16.png

推荐学习:《》

99君

这个人很懒,什么都没留下