• 技术文章 >运维 >Docker

    docker哪个版本内置swarm

    长期闲置长期闲置2022-07-08 15:39:57原创108

    从“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 来进行服务发现配置了。

    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

    推荐学习:《docker视频教程

    以上就是docker哪个版本内置swarm的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:Docker
    上一篇:docker连接mysql报错2003怎么办 下一篇:docker exec是什么意思
    20期PHP线上班

    相关文章推荐

    精选22门好课,价值3725元,开通VIP免费学习!• linux怎么查看docker是否运行• windows7支持使用docker吗• docker运行在物理机还是虚拟机上• 什么是docker微服务• docker镜像中包含什么
    1/1

    PHP中文网