本文将参考官方文档,详细讲解 Docker 集群的相关内容。
将应用部署到集群上,在多个机器上运行。通过将多个机器连接成为一个 Docker 化的集群(swarm
),使得多机器、多容器应用成为可能。
Swarm
是运行 Docker 并连接成为一个集群的机器的聚合。实现了Swarm
之后,你还是按往常一样使用 Docker 的命令,但它们现在是通过swarm manager
在集群上执行。swarm
中的机器可能是实体的也可能是虚拟的,连接到swarm
之后,统一称为nodes
。
swarm manager
可以使用不同的策略来运行容器,可以在构成文件(docker-compose.yml
)里面指定使用的策略。
swarm
中,只有swarm managers
可以执行你的指令,虽然可以授权其他机器加入到swarm
中作为workers
,但它们只提供容量,并没有权限告诉其他机器该做什么不该做什么。
Docker 有单主机(single-host)模式和群(swarm)模式,启用swarm
模式,将使当前机器成为swarm manager
,此后,Docker 就可以运行你在管理的所有swarm
上执行的命令,而不仅仅是当前机器了。
设置swarm
swarm
由多个节点(node
)组成,节点可以是实体机和虚拟机。
1 | # enable swarm mode and make your current machine a swarm manager |
创建集群
- 本地机器上的虚拟机(win10)
- 打开 hyper-v 管理器
- 点击右侧的虚拟交换机管理器
- 点击创建
外部
类型的虚拟交换机 - 将其命名为
myswitch
,并勾选共享主机的活动网络适配器 - 重启机器,否则第二步会出现问题
用节点管理工具
docker-machine
创建几个虚拟机:1
2docker-machine create -d hyperv --hyperv-virtual-switch "myswitch" myvm1
docker-machine create -d hyperv --hyperv-virtual-switch "myswitch" myvm2注意: 创建虚拟交换机时,要选择实体网卡;创建过程要在管理员模式下进行,不然会出现一直停在 waiting for host to start…
查看虚拟机获取其 ip 地址,同样需要管理员模式。
1
2
3
4$ docker-machine ls
NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS
myvm1 - hyperv Running tcp://192.168.10.145:2376 v18.06.0-ce
myvm2 - hyperv Running tcp://192.168.10.155:2376 v18.06.0-ce初始化
swarm
并添加节点
将myvm1
设置为swarm manager
,myvm2
设置为worker
,使用命令
docker-machine ssh myvm1 "docker swarm init --advertise-addr <myvm1 ip>"
进行初始化1
2
3
4
5
6
7
8$ docker-machine ssh myvm1 "docker swarm init --advertise-addr 192.168.10.145"
Swarm initialized: current node (se4zi8fjz25ifcule1i1qgfsz) is now a manager.
To add a worker to this swarm, run the following command:
docker swarm join --token SWMTKN-1-56tiaeik2guz1ajawhif1wpdl947aw2ot6mipbp4q6g0weaebg-7wxuqzaw9uv4jhiia0pft7uzb 192.168.10.145:2377
To add a manager to this swarm, run 'docker swarm join-token manager' and follow the instructions.使用
docker-machine ssh myvm2 "docker swarm join --token <token> <ip>:2377"
将myvm2
加入swarm
1
2
3$ docker-machine ssh myvm2 "docker swarm join --token SWMTKN-1-56tiaeik2guz1ajawhif1wpdl947aw2ot6mipbp4q6g0weaebg-7wxuqzaw9uv4jhiia0pft7uzb 192.168.10.145:2377"
This node joined a swarm as a worker.
成功创建了一个
swarm
,在swarm manager
上运行docker node ls
命令查看节点信息。1
2
3
4$ docker-machine ssh myvm1 "docker node ls"
ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION
se4zi8fjz25ifcule1i1qgfsz * myvm1 Ready Active Leader 18.06.0-ce
8w0vdkds78h9il5bgsasvjebz myvm2 Ready Active 18.06.0-ce如果想要重新开始,可以在每个节点上执行
docker swarm leave
。
在swarm
集群上部署应用
此部分与 Docker 服务部分相同,但要记住,只有swarm manager
可以执行命令,workers
只提供容量。
为swarm manager
配置一个docker-machine
shell
将 Docker 命令发送到虚拟机的方式:
- 除了使用
docker-machine ssh
, - 还有另一种方式,
docker-machine env <machine>
可以获取并运行一个命令,配置当前 shell 以与 VM 上的 Docker 守护程序通信。该方法允许您使用本地docker-compose.yml
文件“远程”部署应用程序,而无需将其复制到任何位置。
windows下配置
运行
docker-machine env myvm1
以获取命令来配置 shell 以与myvm1
通信1
2
3
4
5
6
7
8$ docker-machine env myvm1
SET DOCKER_TLS_VERIFY=1
SET DOCKER_HOST=tcp://192.168.10.145:2376
SET DOCKER_CERT_PATH=C:\Users\Abraham\.docker\machine\machines\myvm1
SET DOCKER_MACHINE_NAME=myvm1
SET COMPOSE_CONVERT_WINDOWS_PATHS=true
REM Run this command to configure your shell:
REM @FOR /f "tokens=*" %i IN ('docker-machine env myvm1') DO @%i执行给出的命令来配置 shell
1
$ @FOR /f "tokens=*" %i IN ('docker-machine env myvm1') DO @%i
运行
docker-machine ls
来验证myvm1
是否为激活机器(旁边有*号标记)1
2
3
4$ docker-machine ls
NAME ACTIVE DRIVER STATE URL SWARM DOCKER ERRORS
myvm1 * hyperv Running tcp://192.168.10.145:2376 v18.06.0-ce
myvm2 - hyperv Running tcp://192.168.10.155:2376 v18.06.0-ce在
swarm manager
上部署 app
通过docker-machine
shell配置,已经连接到了myvm1
,同时,你还可以访问本机的文件,如 Docker 服务篇,运行以下命令在myvm1
上部署应用1
2
3
4
5# 注意确保docker-compose.yml在当前目录下
$ docker stack deploy -c docker-compose.yml getstartedlab
Creating network getstartedlab_webnet
Creating service getstartedlab_web查看服务信息
1
2
3
4
5
6
7$ docker stack ps getstartedlab
ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR PORTS
oyc6dogleu6f getstartedlab_web.1 cj1406942109/get-started:first-demo myvm1 Running Preparing 5 seconds ago
uyrx15qo9lyi getstartedlab_web.2 cj1406942109/get-started:first-demo myvm2 Running Preparing 5 seconds ago
xgbfz939vzmx getstartedlab_web.3 cj1406942109/get-started:first-demo myvm2 Running Preparing 5 seconds ago
wnx5d8pe5oxz getstartedlab_web.4 cj1406942109/get-started:first-demo myvm1 Running Preparing 5 seconds ago
qk5y9zhwyib6 getstartedlab_web.5 cj1406942109/get-started:first-demo myvm2 Running Preparing 5 seconds ago访问集群
现在,你可以通过myvm1
或myvm2
的ip地址来访问部署好的 app访问出现问题: 在开启
swarm
模式之前,请确保swarm
节点之间的以下端口是开放的:- 端口7946 TCP / UDP用于容器网络发现。
端口4789 UDP用于容器入口网络。
参考文章进行配置
清除
可以使用docker stack rm
命令清除stack
1
docker stack rm getstartedlab
如果关闭本地主机,docker机器也会跟着关闭,可以使用
docker-machine ls
查看其状态可以使用
docker-machine start <machine-name>
命令重启关闭的机器。