5.Docker入门(四)Swarm

注意

以下内容完全摘自Docker官方文档,仅为学习及技术分享所用,切勿用于商业用途,转载请注明出处。

以下为正文


了解Swarm

Swarm是Docker内置的集群管理工具。之前几篇文章,我们介绍的都只是“单机版”的Docker,而在实际应用开发和运维过程中,我们常常需要连接多个实例,组成一个集群,以提升整个系统的处理能力。Swarm就是用来连接多个Docker实例,无论是虚拟机还是物理机,只要是安装运行了Docker的主机,都可以被组成集群。
加入集群后,所有的这些Docker实例都称作Nodes(节点)。Swarm manager(管理者节点)是集群中唯一一个可以执行docker命令和对其他实例进行授权验证的节点,起来集群管理者的角色。其他结点只是起到运行docker应用程序,扩充性能的作用,称之为Worker(工作节点)。

swarm集群结构

利用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上。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,194评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,058评论 2 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,780评论 0 346
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,388评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,430评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,764评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,907评论 3 406
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,679评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,122评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,459评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,605评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,270评论 4 329
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,867评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,734评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,961评论 1 265
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,297评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,472评论 2 348

推荐阅读更多精彩内容