Docker Swarm 学习手札
Docker Swarm 节点介绍
运行 Docker 的主机可以主动初始化一个 Swarm
集群或者加入一个已存在的 Swarm
集群,这样这个运行 Docker 的主机就成为一个 Swarm
集群的节点 (node
) 。
节点分为管理 (manager
) 节点和工作 (worker
) 节点。
管理节点用于 Swarm
集群的管理,docker swarm
命令基本只能在管理节点执行(节点退出集群命令 docker swarm leave
可以在工作节点执行)。一个 Swarm
集群可以有多个管理节点,但只有一个管理节点可以成为 leader
,leader
通过 raft
协议实现。
工作节点是任务执行节点,管理节点将服务 (service
) 下发至工作节点执行。管理节点默认也作为工作节点。你也可以通过配置让服务只运行在管理节点。
Docker Swarm 服务和任务介绍
任务 (Task
)是 Swarm
中的最小的调度单位,目前来说就是一个单一的容器。
服务 (Services
) 是指一组任务的集合,服务定义了任务的属性。服务有两种模式:
replicated services
按照一定规则在各个工作节点上运行指定个数的任务。global services
每个工作节点上运行一个任务
两种模式通过 docker service create
的 --mode
参数指定。
搭建 Swarm 集群
初始化集群
格式:docker swarm init
在已经安装好 Docker 的主机上执行如下命令:
执行 docker swarm init
命令的节点自动成为管理节点。
如果你的 Docker 主机有多个网卡,拥有多个 IP,必须使用 --advertise-addr
指定 IP
docker swarm init --advertise-addr 10.228.237.108
获取令牌,并加入
在manager机器执行,让其他服务器加入
离开集群
工作节点:docker swarm leave
管理节点默认是不允许离开集群的,网上说可通过
docker swarm leave -f
退出,但是会造成很大的错误.因此我自个测试时先把 管理节点降为工作节点:docker node demote 服务id
,在进行退出集群….
查看集群信息:
在管理节点使用 docker node ls
查看集群。
部署Swarm 服务
新建服务
类似docker run
的命令…
docker service create -p 8881:80 --name nginx nginx:latest
docker service create --replicas 3 -p 8881:80 --name nginx nginx:latest
查看服务
使用 docker service ls
来查看当前 Swarm
集群运行的服务。
使用 docker service ps
来查看某个服务的详情。
使用 docker service logs
来查看某个服务的日志。
服务伸缩
我们可以使用 docker service scale
对一个服务运行的容器数量进行伸缩。
当业务处于高峰期时,我们需要扩展服务运行的容器数量。
docker service scale nginx=5
当业务平稳时,我们需要减少服务运行的容器数量。
docker service scale nginx=2
删除服务
使用 docker service rm
来从 Swarm
集群移除某个服务。
docker service rm nginx