docker_practice/swarm/intro.md

17 lines
1.3 KiB
Markdown
Raw Normal View History

2015-05-08 20:10:44 +08:00
## 简介
2015-07-16 14:26:47 +08:00
Docker Swarm 是 Docker公司官方在 2014 年 12月初发布的一套管理 Docker 集群的工具。它将一群 Docker 宿主机变成一个单一的,虚拟的主机。
2015-05-21 20:23:53 +08:00
2015-07-16 14:26:47 +08:00
Swarm 使用标准的 Docker API 接口作为其前端访问入口,换言之,各种形式的 Docker 工具比如 DokkuComposeKraneDeisdocker-pyDocker 本身等都可以很容易的与 Swarm 进行集成。
2015-05-21 20:23:53 +08:00
2015-08-25 10:32:53 +08:00
![Swarm 结构图](../_images/swarm.png)
2015-05-21 20:23:53 +08:00
2015-07-16 14:26:47 +08:00
在使用 Swarm 管理docker 集群时,会有一个 swarm manager 以及若干的 swarm nodeswarm manager上运行 swarm daemon用户只需要跟 swarm manager 通信,然后 swarm manager 再根据discovery service的信息选择一个swarm node 来运行container。
2015-05-21 20:23:53 +08:00
2015-07-16 14:26:47 +08:00
值得注意的是 swarm daemon 只是一个任务调度器(scheduler)和路由器(router),它本身不运行容器,它只接受 Docker client 发送过来的请求,调度合适的 swarm node 来运行 container。这意味着即使 swarm daemon 由于某些原因挂掉了,已经运行起来的容器也不会有任何影响。
2015-05-18 21:24:13 +08:00
有以下两点需要注意:
2015-05-21 20:23:53 +08:00
* 集群中的每台节点上面的 Docker 的版本都不能小于1.4
* 为了让 swarm manager 能够跟每台 swarm node 进行通信,集群中的每台节点的 Docker daemon 都必须监听同一个网络接口。