通过Docker Cloud部署应用

如果您在生产环境中使用Docker Community Edition的效果还不错,可以使用Docker Cloud来帮助管理Amazon Web Services、DigitalOcean和Microsoft Azure等主流服务提供商的应用程序。

设置和部署流程是:将Docker Cloud与您的首选提供商连接,授予Docker Cloud权限,为您自动配置和Dockerize虚拟机;使用Docker Cloud创建您的计算资源并创建您的集群;部署您的应用程序。

连接Docker Cloud

可以在标准模式集群模式下运行Docker Cloud。如果在标准模式下运行Docker Cloud,按照以下说明将您的服务提供商连接到Docker Cloud:

如果您在集群模式下运行,请继续看下面的内容。

创建集群

enable Swarm Mode

在云提供商上部署应用程序

首先通过Docker Cloud连接到你的集群,从集群模式的Docker Cloud的web界面中,选择页面顶部的“Swarms”,单击要连接的集群,然后将给定的命令复制粘贴到命令行终端中。

Docker Cloud的web界面

或者,在Docker for Mac或Docker for Windows上,您可以通过桌面菜单直接连接到集群

Docker for Mac的桌面菜单

无论哪种方式,都将打开一个终端,其上下文是您的本地机器,但其Docker命令会路由到您的云服务提供商上运行的集群。您可以直接访问本地文件系统和远程集群,从而启用纯粹的Docker命令。

运行docker stack deploy -c docker-compose.yml getstartedlab在云托管集群上部署应用程序。

$ docker stack deploy -c docker-compose.yml getstartedlab

现在您的应用正在您的云提供商上运行。

运行一些命令来验证部署

您可以使用swarm命令来浏览和管理集群,例如使用docker node ls列出节点:

$ docker node ls

使用docker service ls列出服务:

$ docker service ls

使用docker service ps <service>查看服务的任务:

$ docker service ps vy7n2piyqrtr

在云供应商的机器上开放服务端口

此时,您的应用程序将作为云提供商服务器上的一个集群进行部署,正如刚刚运行的docker命令所证明的那样,但是,您仍然需要打开云服务器上的端口,以便:

  • 允许在工作节点上的redis服务和web服务之间进行通信。
  • 允许入站流量到工作节点上的web服务,以便从Web浏览器访问Hello World和Visualizer。
  • 允许运行管理器的服务器上的入站SSH流量(可能已经在云提供商上设置)

这些是您需要为每项服务公开的端口:

Service Type Protocol Port
web HTTP TCP 80
visualizer HTTP TCP 8080
redis TCP TCP 6379

迭代和清理

通过更改docker-compose.yml文件来扩展应用程序,并使用docker stack deploy命令即时重新部署。通过编辑代码更改应用程序的行为,然后重新构建,推送新的镜像。也可以用docker stack rm清理堆栈,例如:

$ docker stack rm getstartedlab

与您在本地Docker虚拟机上运行集群的场景不同,您的集群以及部署在其上的所有应用程序都将继续在云服务器上运行,无论您是否关闭本地主机。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容