写点什么

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:001149

评论

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

教你如何搞定springboot集成kafka

华为云开发者联盟

kafka springboot 华为云 华为云开发者联盟 企业号2024年5月PK榜

腾讯、阿里、B站最新面经汇总,有的妥妥的凉经

王中阳Go

golang 面试题 大厂面经 Go进阶

报名开启|智能化可观测:可观测开源开发者Meetup

TRaaS

活动报名

得物质量管理体系的建设与应用

得物技术

测试 质量 企业号 2024年5月 PK 榜

NineData亮相GOPS大会:揭秘新时代企业级数据库DevOps最佳实践

NineData

数据库 DevOps 工具 NineData SQL IDE

观测云产品更新 | 监控、场景仪表板、查看器、服务管理、DQL等

观测云

监控

MES给制造业带来看得见的效益

万界星空科技

数字化 工业互联网 制造业 mes 万界星空科技

抖音商品详情:短视频电商的新风向

Noah

漆包线行业你了解多少?专业漆包线行业MES生产管理系统

万界星空科技

制造业 mes 万界星空科技 漆包线mes 漆包线

立即注册 | 线上讲座:基于 NGINX 为现代应用构筑三大安全防线

NGINX开源社区

nginx DevOps DOS攻击 OWASP十大漏洞 NGINX PLUS

软件测试学习笔记丨黑盒测试方法论-场景法

测试人

软件测试

NineData云原生智能数据管理平台新功能发布|2024年4月版

NineData

sql 数据迁移 数据备份 NineData 对比工具

ClickHouse沙龙来了,NineData将分享数据管理与同步的关键技术!

NineData

Clickhouse Meetup 杭州 NineData 迁移同步

跨云厂商的不停机数据库迁移!使用NineData就可以了

NineData

Google 数据库迁移 多云架构 无停机数据库迁移 跨云厂商

京东JD商品sku信息API返回值解读:数据驱动的商品属性研究

技术冰糖葫芦

API boy API 接口 API 文档

什么是蜜罐,在当前网络安全形势下,蜜罐能提供哪些帮助

德迅云安全杨德俊

API主导的商业模式是否将在AI时代蓬勃发展?

幂简集成

AI API

Oracle到PostgreSQL的不停机数据库迁移!

NineData

oracle postgresql NineData 无停机迁移 异常告警

解锁高效创新:IPD策略如何重塑产品开发流程

不在线第一只蜗牛

大数据 产品开发

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