注意
以下内容完全摘自Docker官方文档,仅为学习及技术分享所用,切勿用于商业用途,转载请注明出处。
以下为正文
了解Swarm
Swarm是Docker内置的集群管理工具。之前几篇文章,我们介绍的都只是“单机版”的Docker,而在实际应用开发和运维过程中,我们常常需要连接多个实例,组成一个集群,以提升整个系统的处理能力。Swarm就是用来连接多个Docker实例,无论是虚拟机还是物理机,只要是安装运行了Docker的主机,都可以被组成集群。
加入集群后,所有的这些Docker实例都称作Nodes(节点)。Swarm manager(管理者节点)是集群中唯一一个可以执行docker命令和对其他实例进行授权验证的节点,起来集群管理者的角色。其他结点只是起到运行docker应用程序,扩充性能的作用,称之为Worker(工作节点)。
利用Swarm构建docker集群
这里,我们使用virtualbox来创建两台基于docker driver的虚拟机(即自带docker运行环境),然后在其中一台虚拟机中初始化swarm集群,使其成为swarm manager,另一台虚拟机加入这个集群,成为worker node。
创建两台虚拟机
首先需要安装virtualbox,这里不详述,请参考相关资料。
然后在命令行分别运行以下命令,创建两台虚拟机,分别命名为myvm1和myvm2
docker-machine create --driver virtualbox myvm1
docker-machine create --driver virtualbox myvm2
初始化Swarm
我们可以使用ssh命令向我们创建好的虚拟机发送指令
向myvm1发送以下指令,将在myvm1上运行docker swarm init命令,初始化swarm,并将myvm1注册为swarm manager。
docker-machine ssh myvm1 "docker swarm init"
此时,您可能会遇到关于 需要使用 --advertise-addr的错误
运行以下命令,得到所有docker实例列表,将myvm1的ip地址复制出来
docker-machine ls
然后运行以下命令,指定ip和端口2377作为集群通信端口
docker-machine ssh myvm1 "docker swarm init --advertise-addr 192.168.99.100:2377"
可以看到运行成功初始化swarm,返回以下信息
Swarm initialized: current node <node ID> is now a manager.
To add a worker to this swarm, run the following command:
docker swarm join \
--token <token> \
<ip>:<port>
其中token是该集群的唯一标识,其它worker节点要加入这个集群,必须指定这个token
接下来,我们向myvm2发送以下指令,将其指定为worker节点
docker-machine ssh myvm2 "docker swarm join \
--token <token> \
192.168.99.100:2377"
这样,我们就创建好了包含两台实例的一个swarm集群。
往集群中部署程序
接下来我们使用 上一节 编写的docker-compose.yml文件来往集群中部署一个带负载均衡的分布式web服务。
首先,需要运行scp命令将docker-compose.yml文件远程发送给swarm manager(这里就是myvm1这台实例),放置到目标实例的home目录下。
docker-machine scp docker-compose.yml myvm1:~
然后,我们可以像 上一节 中所学到的一样,运行发布程序的docker stack deploy命令
docker-machine ssh myvm1 "docker stack deploy -c docker-compose.yml getstartedlab"
这样,我们的应用程序就发布到集群中了,运行以下命令可以看到我们在集群中启动了5个docker容器,这五个容器分布到两台docker实例中。
docker-machine ssh myvm1 "docker stack ps getstartedlab"
ID NAME IMAGE NODE DESIRED STATE
jq2g3qp8nzwx test_web.1 username/repo:tag myvm1 Running
88wgshobzoxl test_web.2 username/repo:tag myvm2 Running
vbb1qbkb0o2z test_web.3 username/repo:tag myvm2 Running
ghii74p9budx test_web.4 username/repo:tag myvm1 Running
0prmarhavs87 test_web.5 username/repo:tag myvm2 Running
访问集群
通过docker-machine ls命令可以查看集群中实例列表,就可以看到实例对应的IP地址,您可以复制myvm1或者myvm2的IP地址到浏览器上访问您刚刚创建好的这个集群。通过不断刷新页面,您可以看到页面上显示的Container ID在不断变化,这就是负载均衡的作用,将请求分流到不同的container上。