如果您正在使用微服务架构,则需要在不同机器上处理不同的项目组件,并创建一个主从架构,以便由主节点控制从节点,通过Docker Swarm部署项目可能会节省很多时间,的努力和资源。
Docker Swarm基本上是称为节点的物理机或虚拟机的群集,它们分别运行docker容器,您可以配置所有这些节点以加入由称为swarm管理器的主节点管理的群集。它是一个编排工具,可让您管理部署在不同计算机上的多个Docker容器。这种类型的体系结构可帮助您正确管理资源并有效地工作。它有助于自动进行负载平衡,同时允许您利用Docker容器的功能并确保高服务可用性。
通常,任何Docker Swarm都有两种服务模式可用。一种是“复制服务”模式,它允许您为管理器指定可复制任务的数量,该任务将其分配给所有可用节点。另一种是全局服务模式,该模式根据可用性,能力和要求将任务序列分配给不同的节点。
在本文中,我们将讨论一些最基本,最重要的Docker Swarm命令,这些命令将帮助您启动Swarm项目。
使用hyperv驱动程序创建6台Docker机器,其中一台充当Swarm管理器,而其他5台充当工作节点。
sudo docker-machine create −−driver hyperv manager sudo docker−machine create −−driver hyperv worker1 sudo docker−machine create −−driver hyperv worker2 sudo docker−machine create −−driver hyperv worker3 sudo docker−machine create −−driver hyperv worker4 sudo docker−machine create −−driver hyperv worker5
使用ls命令确认是否已创建计算机。
sudo docker−machine ls
复制管理员的IP地址。
sudo docker−machine ip manager
SSH进入管理器节点。
sudo docker−machine ssh manager
现在,您位于管理员提示中。要初始化群集,请执行以下步骤。
docker swarm init −−advertise−addr <manager−ip>
使用以下命令检查管理器节点内的Docker Swarm状态。
docker node ls
它显示当前只有一个称为管理器的领导者节点。
在管理器节点的SSH会话内,要查找作为Worker或管理器节点加入的命令和令牌,可以使用以下命令。
docker swarm join−token worker docker swarm join−token manager
上面的命令输出特定的命令,您需要这些命令以工作者或管理者的身份加入集群。
现在,我们将看到如何在Manager下将工作节点添加到集群。
在保持管理器SSH会话打开的同时,启动另一个终端并使用以下命令启动worker1 SSH会话。
sudo docker−machine ssh worker1
一旦进入worker1的SSH会话,请从管理器终端复制为作为工作者加入而生成的命令,并将其粘贴到worker1的SSH会话中。成功执行后,您会发现消息“此节点作为工作人员加入了集群”。对其他4个工人也做同样的事情。创建具有1管理器和5个工作器的集群后,可以通过在管理器的SSH会话中键入以下命令来确认相同的结果
docker node ls
创建Swarm集群后,现在可以启动服务了。我们只需要告诉管理器节点我们将要启动服务(运行容器),管理器就会自动分配分发,命令执行和容器调度。在此示例中,我们将启动nginx容器的4个副本并将其公开给端口80。
在管理器SSH会话中,执行以下命令。
docker service create −−replicas 5 −p 80:80 −−name web nginx
业务流程层现在正在工作。等待一段时间后,您可以在管理器SSH会话中执行此命令以确认相同。
docker service ps web
要访问该服务,您可以在任何工作器或管理器节点的浏览器中执行工作器或管理器ip,而不管其容器是否在运行。
目前,您的群集集群中有5个运行Nginx的容器。要最多扩展7个容器,请在管理器SSH会话中使用此命令。
docker service scale web=7
使用此命令确认相同。
docker service ps web
总而言之,在本文中,我们讨论了如何通过创建不同的虚拟机并将管理者和工作人员角色分配给节点来创建和部署Docker Swarm集群。我们还讨论了如何创建和启动Nginx服务并对其进行扩展,并尝试使用任何节点访问它。如果您是Docker开发人员,或者在微服务项目中使用Docker,则一定要对Swarm集群有很好的了解,以扩大项目规模并有效利用资源。为了成功维护大型项目和分布式项目,创建,启动,部署和维护Docker Swarm集群节点非常重要。