写点什么

Docker Swarm 新版本发布对 Kubernetes 的意义

  • 2020-03-13
  • 本文字数:1964 字

    阅读完需:约 6 分钟

Docker Swarm新版本发布对Kubernetes的意义

相比于普通的软件的开发速度,容器编排领域的发展速度相当惊人。基于容器的初创公司呈爆发式增长,这个领域的竞争也愈加激烈。这是一个好的开始,但是技术的选择却成为一个难题。在这样的情况下,我们目前关注了 Docker 和 Swarm。


在 Apprenda,我们的目标就是提交一个有创意的,稳定的,可以在长时间内比较好维护的编排技术。一个健康的社区有三个关键点。在对技术,社区和不同容器编排工具解决方案进行漫长的商业评估之后,我们选择了 Kubernetes。然而,随着其它容器集群管理选项的增加,要重点了解相比于 Kubernetes 他们分别可以提供什么样的功能进行对比。


Docker 即将发布 1.12 版本,这次的发布直接跟 Kubernetes 进行竞争。这次的新版本都是在名为 SwarmKit 的编排系统的基础上建立起来的。Docker Swarm 目前增加了一些有趣的新功能,也属于 Docker 的一部分。比如,Docker CLI 增加了一个将 Swarm 集群实例化的新功能。将 Swarm 实例化其实也就是创建一个 Swarm Manager 和 CA 证书的意思。值得注意的是,这个 CA 证书可以在不需要外部系统的情况下为 Swarm Manager 和所有 Swarm 集群生成证书,同时所有节点之间的交流由 TLS 来保证安全。这也就意味着不会再有不安全的 Swarm 集群了。对于创建和使用 Swarm 的开发者来说,安全已经完全是透明的了。


CLI 同样也有一些新的命令要把节点添加到已经存在的 Swarm 集群中。要注意的是,节点中有 manager 或者 worker 两者之一,但是 worker 可以被升级到 manager,manager 可以被降级到 worker。Swarm managers 使用 RAFT 协议来选举 leader,并且确定共识,这跟 Kubernetes 运用 etcd 工作的机制有点相似。另一方面,workers 使用 Gossip 协议来交流他们之间各自的状态,这样的话,Docker 用户就不再需要外部实体,也不需要键值存储来跟踪不断变化的集群拓扑。


同样,逻辑服务的概念对 Docker 来说也是很新的,是一个被 Docker Cloud 启发的概念。这个服务包括了一对多容器实例,而且这个逻辑观点的介绍使得服务管理更加容易。服务可以被创建,更新和扩容,这也就导致了容器的配置,更新和杀死。


Docker1.12 的一个弱点就是服务发现,在 Kubernetes 中,服务发现还是运行得很顺畅的。更加重要的是,自从项目的开始,“service”为容器代理的概念已经存在于 Kubernetes 中。它只是简单地联系你的集群中的 service,Kubernetes 确保你在容器服务之后连接到正确的 pod(一个或者多个容器的组合)。Kubernetes 也是被设计成模块化,可扩展的,这样的话,它的组件就可以轻松交换,这就使其更加适合你的整体需求。


从 Docker 发布的这个新版本面临来自 Kubernetes 的竞争,Kubernetes 被设计来帮助更新配置,缩放,操作主机上集群间的容器。鉴于 Kubernetes 超强的社区,已经有很多公司在使用 Kubernetes 了。Kube(社区是这么叫它的)同样也获得了企业客户的普遍接受,这些客户同样也希望使用新云原生算法来创建容器化应用程序。


Kubernetes 对自身的定义就是:将容器集群作为单个的系统进行管理,以此来加速开发,简化操作。Kubernetes 是一个开源平台,但是它同时也是 CNCF(Cloud Native Computing Foundation)开发和管理的社区。它从根本上就跟由初创公司控制,不属于开源社区的 Docker/Swarm 不一样。Kubernetes 很厉害,因为它带来的是谷歌十多年大规模运行容器的经验,Red Hat 在企业多年部署和管理开源平台的经验,CoreOS 灵活开发的经验,以及来自很多其他组织和社区成员的优点。


鉴于强大的多元化社区,Kuberentes 是一个跟 Swiss Army Chainsaw 一样灵活有弹性的平台。你可以在裸机上运行 Kubernetes,或者在你能想到的任意云提供商上运行。Kubernetes 另一个很棒的功能就是它同时支持多种类型的容器,比如 Docker 和 RKT 容器,以及多种容器的集群。


最后,Apprenda 已经被提交到 Kubernetes。这是我们所尝试过最强壮的解决方法,同时我们相信它在我们壮大的时候也还是会支持我们。Apprenda 和 Red Hat 也期望 Kubernetes 能够支持 Windows,并且能够运行 windows 容器。要记住的是,其它集群编排服务也不差,但是,就像我开篇提到的——这个领域发展得很快,我们要确保我们处理的是最主动,最稳定和最成熟的项目。我们对 Kubernetes 十分满意,而且自从 1.0 版本发布以来,就一直在生产过程中使用它了。


对于 Kubernetes1.3 版本的发布,我们满怀期待,同时新功能 PetSet(也就是之前的 nominal services)提供新的有状态的基本单元来运行你的 pods,这就需要强大的辨识和存储功能。我们对 Kubernetes1.3 中的“集群联盟”附加的功能也满怀期待!


我很感激整个 Kubernetes 社区为这个项目已经做的和继续做的努力!这真是一个很棒的技术,也是 Apprenda 所需的重要基石。


本文转载自才云 Caicloud 公众号。


原文链接:https://mp.weixin.qq.com/s/-3JBYLoAZDFB964uxl356Q


2020-03-13 19:001042

评论

发布
暂无评论
发现更多内容

区块链+农业,如何升级农业价值链

CECBC

农业

从狗狗币说起 看区块链的未来发展方向

CECBC

狗狗币

Offer收割机!阿里P7大神甩出JSP实战笔记,网友:信息量过大

飞飞JAva

Java

架构实战营模块三作业

竹林七贤

第三次作业

Geek_9cf7b5

新书见面 | 《云原生时代的微服务架构实践》

Damon

微服务 云原生 5月日更

第一个鸿蒙应用

释缘

鸿蒙 HarmonyOS

架构实战营模块3作业

Vic

架构实战营

轶事

言未卜

rocketmq优雅停机往事

捉虫大师

基于OpenPAI细化部署 Hadoop 集群

Damon

hadoop 5月日更

在线体验四大名著情景(地图、游戏)

不脱发的程序猿

开源 程序人生 四大名著

模块2学习总结

TH

架构实战营

智能会话机器人:SaaS 平台的设计与思考

极客志

自然语言处理 chatbot 聊天机器人 智能会话机器人

Nginx 常用配置清单

Java小咖秀

nginx Web 反向代理 HTTP

数仓ETL系统:给强大的“心脏”配上“超级流水线”

华为云开发者联盟

数据库 数据仓库 GaussDB(DWS) ETL系统 MPPDB

双向循环链表:鸿蒙轻内核中数据的“驿站”

华为云开发者联盟

鸿蒙 数据结构 结构体 OpenHarmony 双向循环链表

运维五一不加班,从一套On-Call响应机制开始!

睿象云

运维 告警 智能运维 告警设置 告警管理

NumPy之:使用genfromtxt导入数据

程序那些事

Python 数据分析 Numpy 程序那些事

从5大挑战带你了解多模态机器学习

华为云开发者联盟

机器学习 多模态机器学习 多模态 异构数据

如何快速制作短视频?拥有这个神器,轻松搞定!

奈奈的杂社

短视频 视频剪辑 自媒体

技术探索系列 - 轻松带你掌握JMM(2)

码界西柚

JVM JMM 5月日更

存算解耦的多模型数据管理平台介绍:以星环科技TDH8.0为例

星环科技

人工智能 大数据 云平台 数据管理平台 存算解耦

“区块链+疫情预警”!这个科研团队研发了传染病预警系统

CECBC

疫情

深入浅出 LVS 负载均衡系列(二):DR、TUN 模型原理

UCloud技术

负载均衡

超详细教程:SpringBoot整合MybatisPlus

华为云开发者联盟

Java spring springboot 代码 MyBatisPlus

架构实战营 -- 模块三

永佳

架构实战营

AI英雄出少年!奔赴星辰,他们正在创造黄金时代

百度大脑

AI

STM32低功耗模式下GPIO如何配置最节能?

不脱发的程序猿

嵌入式 stm32 单片机 低功耗模式

nmon和nmon analyser的网盘下载安装与使用

InfoQ_Springup

工具

模块2作业 微信朋友圈高性能复杂度

TH

架构实战营

Docker Swarm新版本发布对Kubernetes的意义_语言 & 开发_才云科技_InfoQ精选文章