Docker Swarm的前世今生

心静只需一杯茗


概述

在我的《Docker Swarm集群初探》一文中,我们实际体验了Docker Swarm容器集群技术的魅力,与《Kubernetes实践录》一文中提到的Kubernetes集群技术相比,Docker Swarm没有Kubernetes显得那么厚重,因此可以认为是更加轻量级的容器集群技术,这也就意味着上手更加方便快捷,使用起来也要省事很多。作为Docker集群技术三(或“四”)架马车之一的Docker Swarm,它从一开始便是Docker官方的“亲儿子”,发展到现在也经历了很多阶段和迭代。作者在学习的过程中也了解了一点其发展历史,发现有几个概念还是挺容易混淆的,因此撰写成文,是梳理,也是总结。



初出茅庐之:经典Swarm

早在2014年底,Docker公司就设计了容器集群的方案组合:Machine + Swarm + Compose。其中Machine主要用于快速创建Docker运行环境,其支持在创建出来的节点上自动部署Swarm,此时的Swarm我们称为 “经典Swarm”,它是一款整合跨节点网络的集群式容器服务,其利用Docker守护进程的API,将多节点的计算资源进行汇总,并提供兼容Docker的运行API,使用者只需要在执行Docker命令工具时,用--host参数将目标设置为Swarm服务的IP和端口,即可操作整个容器集群。

当然此时的Swarm局限性较大,比如:

  • 没有副本和负载均衡的概念,这导致服务无法高可用
  • 当然也更不存在什么服务网络管理和跨节点数据存储这些东西
  • 没有服务模型:集群中服务间关系和启动顺序编排也很复杂

于是就有了下面的SwarmKit的诞生。



发展壮大之:SwarmKit

在2016年2月,Docker公司开始了一个名叫 SwarmKit 的项目。而恰在Docker 1.12 RC之前的一段时间,Docker 发布了 Swarmkit,这是一个独立的、开源的容器编排项目。SwarmKit不同于一开始的经典Swarm,它从一开始就重新设计了一套独立的API和模型体系,并且采用独立的客户端命令行工具:swarmctl

和上面的经典Swarm模型相比,它加入了如下特性:

  • 重新设计的一套独立的API和模型体系
  • 使用了自己的CLI(swarmd命令负责管理,swarmctl命令用于控制)
  • 节点管理、服务模型更加自然,提供编排和调度服务
  • 将过去Swarm依赖的外部集群一致性存储组件Etcd的核心部分内置化

然而此时的SwarmKit并没有提供诸如服务发现、负载均衡和路由等功能。尽管如此,SwarmKit其实已经是我们今天广泛使用的Docker Swarm集群技术的基石。



厚积薄发之:Swarm Mode

Swarm Mode则更进一步,它在Docker 1.12版本开始为大家所周知,一个 docker swarm命令 红遍大江南北,这个所谓的Swarm Mode其实就是我们今天所广泛使用的Docker Swarm集群技术。

然而Swarm Mode并不是一个全新的东西,也并不是一个全新的模式,而是站在SwarmKit的巨人肩膀上发展起来的,是Docker中的一组与集群相关功能的统称而已。Docker将SwarmKit的核心模块内嵌于Docker的后台服务之中,通过不同的命令允许使用者同时以“本节点”和“本集群”这两种视角来操作整个集群,增加了集群的管理、节点的管理、服务的管理和编排等等一系列高级特性,就像在我的《Docker Swarm集群初探》一文中体验的那样。

因此总结一下Swarm Mode就是:

  • 基于Swarmkit编写
  • 支持服务模型以及服务发现、路由和负载均衡等新功能
  • 使用Docker原生态的CLI命令
  • 集成到了Docker engine中(强大的 docker swarm 命令)


对比总结

如果用一张图来表示 Docker、经典Swarm、SwarmKit、Swarm Mode 四个概念之间的关系,则大致可以如下图所示:

四者之间的关系

正如图中所示,SwarmKit 和 Swarm Mode 重叠的部分表示的是相应的项目之间存在代码层面的互相引用或组件形式的依赖,其实 Swarm Mode 所创建的集群本质上并无异于 SwarmKit 集群。

更细致一点,我们从SwarmKit和Swarm Mode二者在一些常用命令操作上的比较来看看二者的区别和联系:

1. 创建集群

  • SwarmKit方式:swarmd
  • SwarmMode方式:docker swarm init

2. 往集群中添加节点

  • SwarmKit方式:swarmd --hostname worknode --join-addr [IP:端口] --join-token [Token]
  • SwarmMode方式:docker swarm join --token [token] [IP:端口]

3. 查看集群节点信息

  • SwarmKit方式:swarmctl node ls
  • SwarmMode方式:docker node ls

4. 创建服务

  • SwarmKit方式:swarmctl service create --name [服务名] --image [镜像名]
  • SwarmMode方式:docker service create --name [服务名] [镜像名]

5. 服务扩容

  • SwarmKit方式:swarmctl service update [服务名] --replicas [副本数目]
  • SwarmMode方式:docker service scale [服务名]=[副本数目]

6. 服务(镜像)升级

  • SwarmKit方式:swarmctl service update [服务名] --image [镜像名]
  • SwarmMode方式:docker service update [服务名] --image [镜像名]

从命令行操作来看,Swarm Mode其实非常类似于SwarmKit,然而前者更加靠近 Docker 原生态圈的命令,因此更加人性化。



后记

如果有兴趣,也可以抽点时间看看作者一些关于容器化、微服务化方面的文章:



来源:https://yq.aliyun.com/articles/602876


智能推荐

docker swarm

Docker Swarm Docker Swarm集群的构建 1.修改主机名 node1(192.168.88.28) node2(192.168.88.4) node3(192.168.88.133) [root@node1 ~]# vim /etc/hosts 添加: 192.168.88.28 node1 192.168.88.4 node2 192.168.88.133 node3 pin...

Docker Swarm

Docker Swarm——命令 docker swarm init命令用户创建一个新的Swarm。执行该命令的节点会成为第一个管理节点,并且会切换到Swarm模式。 docker swarm join-token命令用于查询加入管理节点和工作节点到现有Swarm时所使用的命令和Token。要获取新增管理节点的命令,请执行docker swarm join-token ma...

给我10分钟,带你看懂Docker和K8S的前世今生

目录 1、Docker的开源之路 2、Docker为什么火了 3、Docker介绍 4、K8S介绍 5、总结 Docker -- 本身并不是容器,它是创建容器的工具,是应用容器引擎; K8S -- 就是基于容器的集群管理平台,可以对Docker及容器进行更高级、更灵活的管理,它的全称,是kubernetes。 1、Docker的开源之路 2010年,几个搞IT的年轻人,在美国旧金山成立了一家名叫&...

阿里P8架构师带你详细了解Docker的前世今生

虚拟化 要解释清楚 Docker,首先要解释清楚容器(Container)的概念。要解释容器的话,就需要从操作系统说起。操作系统太底层,细说的话一两本书都说不清楚。这里就一句话来总结一下:操作系统(Operating System,简称OS)是管理计算机硬件与软件资源的计算机程序,并且为软件运行提供通用服务的系统软件。 随着硬件的性能提升,软件种类的丰富,有两种情况变得很常见: 1.硬件性能过剩&...

docker-8-docker swarm docker stack

想要学习docker的同学建议阅读官方文档,只有那里解释的最详细最正确 docker swarm官方文档 因为官方文档上使用virtualbox进行虚拟化,然后在虚拟出来的两台主机上搭建的swarm,这种不符合实际使用,故本文进行了修改,运行在了两台linux服务器上 学习docker的同学大多知道k8s(Kubernetes),k8s是docker集群的调度器,用来节点、任务分配等。docker...

猜你喜欢

【swarm】关于docker swarm的平面隔离设置

一、平面隔离概念   为了提升兼容性和管理的便利性,一些产品在运维架构设计上的控制平面、用户平面和管理平面在缺省情况下没有隔离。 用户可以通过业务接口登录并管理设备,客观上使被攻击的可能性增大,攻击者可以较容易的通过业务接口尝试攻击管理平面。 因此,产品在运维架构设计上,要支持用户安装时,配置三面隔离:隔离控制平面、用户平面和管理平面,以保护管理平面不受外部攻击。   &nbs...

【swarm】从docker单机到swarm模式的网络变化

一、单机网络   #  yum  -y install docker    # ip addr list # docker network ls   同一个主机不同容器之间,容器和外部网络之间的通讯,用到docker0网桥。     一、swarm网络   #  docker swarm init ...

原型对象,原型链

函数都有prototype属性,它指向原型对象。 实例对象有__proto__属性,它指向对象原型 每一个原型对象都有constructor输赢,指向构造函数,每一个原型对象又具有__proto__属性,这个指向Object.prototype.在这里插入图片描述...

Node 调用 dubbo 服务的探索及实践

2.Dubbo简介 2.1 什么是dubbo Dubbo是一款高性能、轻量级的开源Java RPC框架,它提供了三大核心能力:面向接口的远程方法调用,智能容错和负载均衡,以及服务自动注册和发现。 2.2 流程图 Provider : 暴露服务的服务提供方。 Consumer : 调用远程服务的服务消费方。 Registry : 服务注册与发现的注册中心。 Monito...

mysql总结

mysql基础入门的总结     关于数据库:     数据库是软件开发人员要掌握的基本工具,软件的运行的过程就是操作数据的过程,数据库中的数据无非就是几个操作:增-删-查-改。         Mysql安装完成后,需要配置变量环境,找到配置路径path,然后把mysql安装目录bin文件导入就可以了。 然后运行cm...

问答精选

Correctly formatting GCM notifications?

I'm currently trying out the google cloud messaging service with its sample application "Guestbook." https://developers.google.com/cloud/samples/mbs/ I'm attempting to send notifications tha...

Are there any performance benefits of using Asynchronous functions over Synchronous in Node Js?

Now I came across an article that distinguishes between an Asynchronous function and Synchronous functions. From my understanding of the different examples and explanations, synchronous functions are ...

Python: Costing calculator output

Good day all I'm busy creating a small costing calculator for the signage department. I'm not getting the calculator to output the amount. Brief Description: You enter the height and width and then wh...

Flask-SQLAlchemy - model has no attribute 'foreign_keys'

I have 3 models created with Flask-SQLalchemy: User, Role, UserRole role.py: user.py: user_role.py: If I try (in the console) to get all users via User.query.all() I get AttributeError: 'NoneType' obj...

Seeding many PRNGs, then having to seed them again, what is a good quality approach?

I have many particles that follow an stochastic process in parallel. For each particle, there is a PRNG associated to it. The simulation must go through many repetitions to get average results. For ea...

相关问题

相关文章

热门文章

推荐文章

相关标签

推荐问答