Docker Cloud实现部署应用操作详解

 更新时间:2018年06月21日 14:42:25   作者:何小有  
这篇文章主要介绍了Docker Cloud实现部署应用操作,较为详细的分析了Docker Cloud部署应用的步骤、命令、实现方法及相关操作注意事项,需要的朋友可以参考下

本文实例讲述了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:

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

创建集群

如果使用的是Amazon Web Services(AWS),则可以在AWS上自动创建一个集群
如果使用的是Microsoft Azure,则可以在Azure上自动创建一个集群
否则,在Docker Cloud UI中创建您的节点,并通过Docker Cloud运行docker swarm init和docker swarm join命令。最后,通过点击屏幕顶部的“enable Swarm Mode”,并注册创建的集群

enable Swarm Mode

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

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

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

无论哪种方式,都将打开一个终端,其上下文是您的本地机器,但其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 WorldVisualizer
  • 允许运行管理器的服务器上的入站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虚拟机上运行集群的场景不同,您的集群以及部署在其上的所有应用程序都将继续在云服务器上运行,无论您是否关闭本地主机。

希望本文所述对大家docker容器的使用有所帮助

相关文章

  • 连接docker里面的mysql失败解决方法

    连接docker里面的mysql失败解决方法

    这篇文章主要介绍了连接docker里面的mysql失败解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • Docker配置代理的详细步骤记录

    Docker配置代理的详细步骤记录

    docker是一个流行的容器化平台,它让应用程序可以在操作系统层面上隔离运行,从而提供了更高的可移植性和可靠性,这篇文章主要给大家介绍了关于Docker配置代理的详细步骤,需要的朋友可以参考下
    2024-08-08
  • 使用docker部署django的详细步骤

    使用docker部署django的详细步骤

    当用Django框架开发的网站项目完成后上线的话可以用物理主机、虚拟机来部署,也可以容器,下面这篇文章主要给大家介绍了关于使用docker部署django的详细步骤,需要的朋友可以参考下
    2022-08-08
  • Docker中Compose与Kubernetes的区别详解

    Docker中Compose与Kubernetes的区别详解

    这篇文章主要给大家介绍了关于Docker中Compose与Kubernetes区别的相关资料,Docker Compose和Kubernetes(简称k8s)都是容器编排工具,需要的朋友可以参考下
    2023-08-08
  • Docker私有仓库Registry部署的实现

    Docker私有仓库Registry部署的实现

    这篇文章主要介绍了Docker私有仓库Registry部署的实现,私有仓库最常用的就是Registry、Harbor两种,本文详细介绍如何搭建registry私有仓库,感兴趣的可以了解一下
    2020-06-06
  • 关于Jenkins + Docker + ASP.NET Core自动化部署的问题(避免踩坑)

    关于Jenkins + Docker + ASP.NET Core自动化部署的问题(避免踩坑)

    这篇文章主要介绍了关于Jenkins + Docker + ASP.NET Core自动化部署的问题,本文给大家带来了docker安装方法及一些注意事项,内容有点小长,希望朋友们耐心看完,一定有收获
    2021-05-05
  • linux和docker下mysql安装方式

    linux和docker下mysql安装方式

    本文详细介绍了在Linux系统中通过命令行安装MySQL的步骤,包括编辑yum源、下载并启动MySQL服务、登录和修改密码等操作,同时,文中也提供了在Docker环境下安装MySQL的流程,涵盖了拉取MySQL镜像、查看运行状态及登录MySQL的方法
    2024-09-09
  • 使用Dockerfile.dockerignore提升Docker镜像构建速度

    使用Dockerfile.dockerignore提升Docker镜像构建速度

    这篇文章主要为大家介绍了使用Dockerfile.dockerignore提升Docker镜像构建速度,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪<BR>
    2023-10-10
  • Docker daemon 无法启动: does not match with stored UUID错误解决办法

    Docker daemon 无法启动: does not match with stored UUID错误解决办法

    这篇文章主要介绍了Docker daemon 无法启动: does not match with stored UUID错误解决办法的相关资料,需要的朋友可以参考下
    2016-11-11
  • Docker部署Mysql8的实现步骤

    Docker部署Mysql8的实现步骤

    本文主要介绍了Docker部署Mysql8的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07

最新评论