音效素材网提供各类素材,打造精品素材网站!

站内导航 站长工具 投稿中心 手机访问

音效素材

Docker集群的创建与管理实例详解
日期:2018-06-21 12:09:35   来源:脚本之家

本文详细讲述了Docker集群的创建与管理。分享给大家供大家参考,具体如下:

在《Docker简单安装与应用入门教程》中编写一个应用程序,并将其转化为服务,在《Docker分布式应用教程》中,使应用程序在生产过程中扩展5倍,并定义应该如何运行。现在将此应用程序部署到集群上,并在多台机器上运行它,通过将多台机器连接到Dockerized集群上,使多容器、多机器应用成为可能。

Swarm(集群)是运行Docker并加入到一个集群中的一组机器,在这种情况下,您将继续运行以往的Docker命令,但是现在它们将由swarm manager(集群管理器)在集群上执行。集群中的机器可以是物理的或虚拟的,加入集群后,它们被称为nodes(节点)。集群管理器可以使用多种策略来运行容器,比如emptiest node(最空的节点),它使用容器填充最少使用的机器。或者global(全局),它确保了每台机器只能得到指定容器的一个实例。您可以指示集群管理器在组成文件中使用这些策略,就像您已经使用的策略一样。

集群管理器是集群中唯一可以执行命令的机器,或者授权其他机器作为workers(工人)加入集群。工人只是在那里提供能力,并没有权力告诉任何其他机器可以做什么和不可以做什么。到目前为止,您已经在本地机器上以单主机模式使用Docker,但是Docker也可以切换到集群模式,这就是使用集群的原因。当立即启用集群模式使当前机器成为集群管理器时,Docker将运行您正在管理的集群上执行的命令,而不仅仅是在当前的机器上。

创建一个集群

一个集群由多个节点组成,可以是物理机或虚拟机,做法很简单,运行docker swarm init来启用集群模式,并让你的当前机器成为集群管理器,然后在其他机器上运行docker swarm join让它们作为工人加入集群。

接下来使用虚拟机快速创建一个集群,需要一个可以创建虚拟机(VMs)的虚拟机管理程序,在机器上安装Oracle VirtualBox 应用程序。如果是Windows 10系统,而且安装了Hyper-V,则无需安装VirtualBox,而应该使用Hyper-V。

现在,使用docker-machine创建几个虚拟机,使用VirtualBox驱动程序:

$ docker-machine create --driver virtualbox myvm1
$ docker-machine create --driver virtualbox myvm2

您现在创建了两个名为myvm1和myvm2的虚拟机,使用下面命令列出机器并获取其IP地址:

$ docker-machine ls

第一台机器将作为管理员,执行管理命令,认证工人加入群体,第二台机器将成为工人。可以使用docker-machine ssh将命令发送到虚拟机,执行docker swarm init使myvm1成为集群管理器:

$ docker-machine ssh myvm1 "docker swarm init --advertise-addr <myvm1的ip>"

在执行docker swarm init后,响应中会包含一个预配置的docker swarm join命令,您可以在要添加的任何节点上运行该命令。复制这个命令,并通过docker-machine ssh把它发送到名为myvm2的虚拟机,让myvm2作为工人加入新的集群:

$ docker-machine ssh myvm2 "docker swarm join --token <token> <ip>:2377"

将myvm2加入集群时,端口号要选择2377,因为端口2376是Docker守护进程端口,不要使用此端口,否则可能会遇到错误。在管理器上运行docker node ls以查看集群中的节点:

$ docker-machine ssh myvm1 "docker node ls"

现在集群己经创建完成,如果想要删除集群,可以使用docker swarm leave在每个节点运行。

在集群上部署应用程序

现在只要重复《Docker分布式应用教程》中使用的过程来部署新的集群,只要记住,只有像myvm1这样的集群管理器才能执行Docker命令,工人只是干活的。

到目前为止,您已经在docker-machine ssh中包装了Docker命令来与虚拟机进行通信,另一个选择是运行docker-machine env <machine>来获取并运行一个配置当前的命令,以便与虚拟机上的Docker守护进程通信。这个方法更好,因为它允许使用本地docker-compose.yml文件来“远程”部署应用程序,而不需要将它复制到任何地方。

执行docker-machine env myvm1命令,复制输出的最后一行提供的命令,然后粘贴并运行该命令,以将终端配置为与集群管理器myvm1对话:

$ docker-machine env myvm1
$ eval $(docker-machine env myvm1)

运行docker-machine ls以验证myvm1现在是活动的机器,即活动状态旁边有星号:

$ docker-machine ls

现在可以使用myvm1的权限作为集群管理器,通过使用docker stack deploy命令和docker-compose.yml的本地副本来部署应用程序。通过docker-machine命令配置连接到myvm1,仍然可以访问本地主机上的文件,确保在docker-compose.yml文件同一个目录下,运行以下命令在myvm1上部署应用程序:

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

就这样,应用程序被部署在一个集群上,现在,您可以使用Docker命令看到服务和关联的容器已经在myvm1和myvm2之间分配了:

$ docker stack ps getstartedlab

访问集群

现在可以从myvm1或myvm2的IP地址访问应用程序,网络在它们之间共享并负载平衡。运行docker-machine ls来获取虚拟机的IP地址,并在浏览器中访问其中的任何一个,或使用curl命令访问。

您将看到五个不同的容器ID,它们都是随机循环的,展示了负载平衡。两个IP地址工作的原因是集群中的节点参与入口路由网络,这可以确保部署在群集中某个端口的服务始终将该端口保留给自己,而不管哪个节点实际上正在运行该容器。以下是三节点集群上端口8080上发布一个名为my-web的服务的路由网络示意图:

可以通过更改docker-compose.yml文件来缩放应用程序,编辑代码更改应用程序的行为,然后重新构建,然后推送新的镜像,只需再次运行docker stack deploy来部署这些更改。可以使用docker swarm join命令将任何物理或虚拟机器加入到此集群,并将容量添加到集群,之后只需运行docker stack deploy部署,应用将利用新的资源。

清理并重新启动

可以使用docker stack rm清理堆栈,例如:

$ docker stack rm getstartedlab

可以使用以下命令取消当前终端中的docker-machine环境变量:

$ eval $(docker-machine env -u)

这会将终端与docker-machine创建的虚拟机断开连接,并允许继续在同一个终端中工作。如果关闭本地主机,Docker机器将停止运行,您可以通过运行docker-machine ls来检查机器的状态:

$ docker-machine ls

要重新启动已停止的机器,可以运行:

$ docker-machine start <machine-name>

如果你想删除这个集群,可以使用docker-machine ssh myvm2 "docker swarm leave"命令,或者使用docker-machine ssh myvm1 "docker swarm leave --force"强制删除。

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

    您感兴趣的教程

    在docker中安装mysql详解

    本篇文章主要介绍了在docker中安装mysql详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编...

    详解 安装 docker mysql

    win10中文输入法仅在桌面显示怎么办?

    win10中文输入法仅在桌面显示怎么办?

    win10系统使用搜狗,QQ输入法只有在显示桌面的时候才出来,在使用其他程序输入框里面却只能输入字母数字,win10中...

    win10 中文输入法

    一分钟掌握linux系统目录结构

    这篇文章主要介绍了linux系统目录结构,通过结构图和多张表格了解linux系统目录结构,感兴趣的小伙伴们可以参考一...

    结构 目录 系统 linux

    PHP程序员玩转Linux系列 Linux和Windows安装

    这篇文章主要为大家详细介绍了PHP程序员玩转Linux系列文章,Linux和Windows安装nginx教程,具有一定的参考价值,感兴趣...

    玩转 程序员 安装 系列 PHP

    win10怎么安装杜比音效Doby V4.1 win10安装杜

    第四代杜比®家庭影院®技术包含了一整套协同工作的技术,让PC 发出清晰的环绕声同时第四代杜比家庭影院技术...

    win10杜比音效

    纯CSS实现iOS风格打开关闭选择框功能

    这篇文章主要介绍了纯CSS实现iOS风格打开关闭选择框,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作...

    css ios c

    Win7如何给C盘扩容 Win7系统电脑C盘扩容的办法

    Win7如何给C盘扩容 Win7系统电脑C盘扩容的

    Win7给电脑C盘扩容的办法大家知道吗?当系统分区C盘空间不足时,就需要给它扩容了,如果不管,C盘没有足够的空间...

    Win7 C盘 扩容

    百度推广竞品词的投放策略

    SEM是基于关键词搜索的营销活动。作为推广人员,我们所做的工作,就是打理成千上万的关键词,关注它们的质量度...

    百度推广 竞品词

    Visual Studio Code(vscode) git的使用教程

    这篇文章主要介绍了详解Visual Studio Code(vscode) git的使用,小编觉得挺不错的,现在分享给大家,也给大家做个参考。...

    教程 Studio Visual Code git

    七牛云储存创始人分享七牛的创立故事与

    这篇文章主要介绍了七牛云储存创始人分享七牛的创立故事与对Go语言的应用,七牛选用Go语言这门新兴的编程语言进行...

    七牛 Go语言

    Win10预览版Mobile 10547即将发布 9月19日上午

    微软副总裁Gabriel Aul的Twitter透露了 Win10 Mobile预览版10536即将发布,他表示该版本已进入内部慢速版阶段,发布时间目...

    Win10 预览版

    HTML标签meta总结,HTML5 head meta 属性整理

    移动前端开发中添加一些webkit专属的HTML5头部标签,帮助浏览器更好解析HTML代码,更好地将移动web前端页面表现出来...

    移动端html5模拟长按事件的实现方法

    这篇文章主要介绍了移动端html5模拟长按事件的实现方法的相关资料,小编觉得挺不错的,现在分享给大家,也给大家...

    移动端 html5 长按

    HTML常用meta大全(推荐)

    这篇文章主要介绍了HTML常用meta大全(推荐),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参...

    cdr怎么把图片转换成位图? cdr图片转换为位图的教程

    cdr怎么把图片转换成位图? cdr图片转换为

    cdr怎么把图片转换成位图?cdr中插入的图片想要转换成位图,该怎么转换呢?下面我们就来看看cdr图片转换为位图的...

    cdr 图片 位图

    win10系统怎么录屏?win10系统自带录屏详细教程

    win10系统怎么录屏?win10系统自带录屏详细

    当我们是使用win10系统的时候,想要录制电脑上的画面,这时候有人会想到下个第三方软件,其实可以用电脑上的自带...

    win10 系统自带录屏 详细教程

    + 更多教程 +
    WIN服务器linux服务器FTP服务器DNS服务器其他