看Kubernetes 1.5之后如何称霸容器编排管理界

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 2016 年 12 月, Kubernetes 1.5 的发布,上述 Linux 和 Windows 一起运行的梦想终于得以实现。 微软宣布支持 Kubernetes Kubernetes 眼下已成为众多容器管理系统核心——比如 CoreOS 公司的商务平台 Tectonic。

2016 年 12 月, Kubernetes 1.5 的发布,上述 Linux 和 Windows 一起运行的梦想终于得以实现。

微软宣布支持 Kubernetes

Kubernetes 眼下已成为众多容器管理系统核心——比如 CoreOS 公司的商务平台 Tectonic。最近,微 软也宣布已将 Kubernetes 整合到其公有云上。

“现在,我们支持 Kubernetes,它会比原来更加好用,并且宣布 Azure 容器服务的预发布版本,”Azure 的计算总监,Corey Sanders 在微软 Azure 发布的时候说道,“对 Kubernetes 本地有更高等级的支持,会为容器编排引擎提供了另外一个开源选择。”

微软也支持 Docker Swarm 和 Mesosphere 的 DC/OS,但是似乎 Kubernetes 更加有掌控容器编排界的趋势。随着事物的发展速度变快,Kubernetes 可能并非容器界的唯一一匹快马,但是它确实是很多厂商的选择。它的地位至此,值得深思。

开源软件公司 Red Hat 的高级产品经理,同时也是决定将 Red Hat 开源 OpenShift PaaS 进行标准化的小组成员之一的 Joe Fernandes 对容器管理系统非常了解。
2013 年,该公司想要创建一个本土的容器管理系统,那时,公司看到了 Mesos,并且跟 Google 讨论 Kubernetes 的开源计划,Joe Fernandes 说,“就功能上来说,Kubernetes 远远超过

Mesos 和 Marathon。”
Gartner 研究副总裁 Richard Watson 说,“这表明微软也希望成为 Kubernetes 生态系统内的重要贡献者。用户期望 Kubernetes 在 Windows 上正常工作,未来能够有 Windows 的集群功能,这对混合环境的IT部门很重要。”

Kubernetes 如何从众多容器编排工具中脱颖而出

但是对于 Fernandes 来说同样重要的就是 Google 在容器上的继承,他说,“就像他们之前说的那样,他们运行的所有东西都已容器化。Kubernetes 不是 Borg(Google 的资源编排软件),但是编写 Kubernetes 花费了他们过去使用 Borg 十几年的经验。

另外一个很重要的东西就是(或许对于像 Red Hat 这样的开源公司来说并不意外),Kubernetes 项目现在隶属于 CNCF 旗下,Google 则是开源项目的赞助商之一(在 Fernandes 看来,这绝对是一个加分项)。“我们在 Kubernetes 开源之前就跟 Google 聊过,但是现在 Kubernetes 项目发展很快,有很多厂商支持它,它增加新功能的速度非常快,能够运行很多不同类型的工作负载。”Fernandes 说道。

相比之下,他指出,虽然 Mesos 有 Apache 的支持,但是没有像 Kubernetes 那么多厂商支持。“只有 Mesosphere——虽然有几个厂商确实在云的选择(比如微软)上提供了几个选项。”
Fernandes 认为原因是 Mesos 的代码库不容易拓展,也不容易在它上面创建服务。他说,“我觉得他们的开源社区做得不太好。”

在他认为,Kubernetes 最大的竞争对手是 do-it-yourself 实现方法。但是现实就是,容器领域扩张速度非常快,这也使得实现方法不切实际。

Fernandes 说,“Kubernetes 每年更新 4 次,Docker 每年更新 3-4 次,如果自己动手创建这些解决方法会非常耗时间,所以大多数企业都选择更有效率地创建应用以及让第三方公司来创建编排平台。”

现在有一些容器编排平台供你选择。按照道理来讲,Me sos 和 Docker Swarm 短时间内是不会被淘汰掉的。但是 Kubernetes 也有理由继续扩张式发展。

目前,类似于像 Tectonic 这样的平台,以及完全开源解决方案(比如 OpenShift)都是建立在 Kubernetes 的技术之上的,未来,会有更多的产品(不仅限于上述两种产品类型)选择 Kubernetes 作为底层技术。

Kubernetes 的优势

Kubernetes 并非市唯一的容器管理平台(其他还有 Docker Swarm 或 Mesos 等),但它是行业首选。这是为什么呢?

从一个高层次角度看,Kubernetes 吸引人的一点是它提供了一个平台,实现容器化应用程序的编写并在各类型云基础设施上运行。它将公有云与私有云之间的复杂基础设施差异抽象化。并且,Kubernetes 下一步可以让开发人员运行任何适合在 Kubernetes 运行的应用程序。Box 的合伙人 Sam Ghods 认为只要一个二进制文件可以运行,那它就能在 Kubernetes 上运行。

使用 Kubernetes,开发人员可以快速地部署应用程序,同时无须面对传统平台所具有的风险(想象一下跨多操作系统环境的横向扩展)、动态地扩展应用程序以及更佳的资源分配。

推动 Kubernetes 的另外一个原因,是企业硬件使用率的下降。有些公司报告说,由于容器的轻量特性以及(相比传统架构)更快速杀掉未使用的实体,对硬件的需求降低了 40-50%。eBay 是 Kubernetes 著名的支持者及用户,它声称在转换到该平台后服务器的开销支出急剧减少。

Kubernetes 的最大的优势之一是,它面向的是社区而不是一个技术规范,这让它的功能更加强大。Google 将其作为一个开源项目发布,获得超过 1 千个社区贡献者及 3 万 4 千个提交的支持。其社区比 Mesos(第二大的竞争社区)要大 5 倍,比所有竞争社区加起来还大。

Kubernetes 的弊端:

Kubernetes 在圈内广受赞誉,但是它自身也有缺点。当涉及到(大规模)初始部署的时候,设置起来步骤复杂、操作困难。而且它需要有特殊技能的工程师来操作,这样的人才在现目前的工程领域里还比较难找。

其次,Kubernetes 对于容器来说,是一个第三方管理系统。容器所历经的弊端和成长,对 Kubernetes 所提供的服务也会有影响。

调度器领域现在缺少 Kubernetes。默认设置下,Kubernetes 规划器依赖于由应用程序提出的资源分配需求,并不会考虑实时消耗情况。这样操作,每个节点上会产生资源碎片。

最后一点,能够在容器中运行的负载领域会限制 Kubernetes 被普及,但是这个问题 Kubernetes 眼下还无法解决。鉴于崩溃的倾向,很多工程师犹豫要不要在容器中运行“关键任务”负载,毕竟存储数据并不是容器的设计初衷。惯例是,大家会使用那些在崩溃时不会在容器内引起宕机的应用程序。

Kubernetes 的未来

即使有这样那样的缺点,也不阻挡不了像 Goldman Sachs、Box、SAP 和纽约时报等公司使用 Kubernetes 的步伐,他们将 Kubernetes 平台列入了他们下一个数据中心的计划。

应用程序是很多商务的血液。很多公司正在努力满足日益加快的部署时间和高质量应用程序的需求。这些需求就是开发人员为什么要涌向容器的原因。随着容器技术的爆发,Kubernetes 在市场中也找好了自己的定位。平台领域还有很多潜在性能可以挖掘,但是如果规模变大的还,它是很难管理的。在产品中,初始设置和大规模运行 Kubernetes 之间存在着巨大的鸿沟。在接下来这一年中,第三方管理平台之间的竞争将会很激烈。对于 Kubernetes 来说,不偏离它过去所做的成就显得尤为重要。如果社区能够合理地对平台进行扩容,那么 Kubernetes 的未来将无可限量。

Kubernetes 2017 发展趋势

2016 是 Kubernetes 作为开源容器编排工具在技术圈疯狂圈地的一年。世界范围内成千上万的代码贡献者都在争相为 Kubernetes 贡献功能。越来越多的公司选择 Kubernetes 作为最佳工具,实现在生产环境中容器化微服务的高可用。了解Kubernetes2016年大事记录

版本发布记录:2016 年 3 月 16 日发布 1.2 版,7 月 1 日发布 1.3 版,9 月 27 日发布 1.4 版,12 月 14 日发布 1.5 版:

20170206213723

据上图数据来看,2016 年 Kubernetes 稳定版发布 34 次,发布次数相比 2015 年增加了 112.5%,平均发布间隔为 11 天。2016 年度,K8S 连同 alpha 版和 beta 版共计发布 111 次。

20170206213723

(Kubernetes 2017 版本发布时间线)

2017 年,Kubernetes 预计发布 4 个版本:1.6、1.7、1.8 和 1.9。Github 上显示,1.6 版本将在三月发布,发布频率基本上保持 3 个月一更的状态。

据悉,很多应用使用 GPU 可以提升效率,所以 Kubernetes 上游计划在其 1.6 发行版本中加入 GPU 功能,提升应用程序运行效率。

本文转自中文社区-看Kubernetes 1.5之后如何称霸容器编排管理界

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
2天前
|
Kubernetes 监控 开发者
掌握容器化:Docker与Kubernetes的最佳实践
【10月更文挑战第26天】本文深入探讨了Docker和Kubernetes的最佳实践,涵盖Dockerfile优化、数据卷管理、网络配置、Pod设计、服务发现与负载均衡、声明式更新等内容。同时介绍了容器化现有应用、自动化部署、监控与日志等开发技巧,以及Docker Compose和Helm等实用工具。旨在帮助开发者提高开发效率和系统稳定性,构建现代、高效、可扩展的应用。
|
3天前
|
Kubernetes 负载均衡 Cloud Native
云原生应用:Kubernetes在容器编排中的实践与挑战
【10月更文挑战第27天】Kubernetes(简称K8s)是云原生应用的核心容器编排平台,提供自动化、扩展和管理容器化应用的能力。本文介绍Kubernetes的基本概念、安装配置、核心组件(如Pod和Deployment)、服务发现与负载均衡、网络配置及安全性挑战,帮助读者理解和实践Kubernetes在容器编排中的应用。
17 4
|
3天前
|
Kubernetes 监控 Cloud Native
云原生应用:Kubernetes在容器编排中的实践与挑战
【10月更文挑战第26天】随着云计算技术的发展,容器化成为现代应用部署的核心趋势。Kubernetes(K8s)作为容器编排领域的佼佼者,以其强大的可扩展性和自动化能力,为开发者提供了高效管理和部署容器化应用的平台。本文将详细介绍Kubernetes的基本概念、核心组件、实践过程及面临的挑战,帮助读者更好地理解和应用这一技术。
21 3
|
4天前
|
存储 运维 Kubernetes
云端迁移:备份中心助力企业跨云迁移K8s容器服务平台
本文将简要介绍阿里云容器服务ACK的备份中心,并以某科技公司在其实际的迁移过程中遇到具体挑战为例,阐述如何有效地利用备份中心来助力企业的容器服务平台迁移项目。
|
6天前
|
运维 Kubernetes Cloud Native
云原生入门:Kubernetes和容器化的未来
【10月更文挑战第23天】本文将带你走进云原生的世界,探索Kubernetes如何成为现代软件部署的心脏。我们将一起揭开容器化技术的神秘面纱,了解它如何改变软件开发和运维的方式。通过实际的代码示例,你将看到理论与实践的结合,感受到云原生技术带来的革命性影响。无论你是初学者还是有经验的开发者,这篇文章都将为你开启一段新的旅程。让我们一起踏上这段探索之旅,解锁云原生技术的力量吧!
|
9天前
|
JSON Kubernetes 容灾
ACK One应用分发上线:高效管理多集群应用
ACK One应用分发上线,主要介绍了新能力的使用场景
|
10天前
|
Kubernetes 持续交付 开发工具
ACK One GitOps:ApplicationSet UI简化多集群GitOps应用管理
ACK One GitOps新发布了多集群应用控制台,支持管理Argo CD ApplicationSet,提升大规模应用和集群的多集群GitOps应用分发管理体验。
|
1月前
|
Kubernetes Cloud Native 云计算
云原生之旅:Kubernetes 集群的搭建与实践
【8月更文挑战第67天】在云原生技术日益成为IT行业焦点的今天,掌握Kubernetes已成为每个软件工程师必备的技能。本文将通过浅显易懂的语言和实际代码示例,引导你从零开始搭建一个Kubernetes集群,并探索其核心概念。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你打开一扇通往云原生世界的大门。
100 17
|
25天前
|
Kubernetes 应用服务中间件 nginx
搭建Kubernetes v1.31.1服务器集群,采用Calico网络技术
在阿里云服务器上部署k8s集群,一、3台k8s服务器,1个Master节点,2个工作节点,采用Calico网络技术。二、部署nginx服务到k8s集群,并验证nginx服务运行状态。
283 1
|
30天前
|
Kubernetes Cloud Native 微服务
微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
微服务实践之使用 kube-vip 搭建高可用 Kubernetes 集群
85 1

相关产品

  • 容器服务Kubernetes版