从“docker 1.12.0”版本开始内置swarm;swarm是用于管理docker集群的平台,采用go语言完成的开发,从“1.12.0”版本开始,“Docker Swarm”已经包含在Docker引擎中,并且已经内置了服务发现工具,因此不需要再配置Etcd或者Consul来进行服务发现配置。
本教程操作环境: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 来进行服务发现配置了。
上图可以看出,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根据个数以此类推。
推荐学习:《docker视频教程》