在过去的几年中,Kubernetes已经成为了数不多的,使自己成为所属领域的行业标准的新技术之一。为了理解Kubernetes带来如此变革的原因,我们需要沿着虚拟化内存之路回顾一番。为方便叙述,本文中会简化各种体系结构类型,突出其核心特征和演变。

一对一(One to One)

在微型计算机之初,物理硬件主要使用一个且仅有一个操作系统,而且大多数应用程序(如数据库,Web服务器和网站)通常只有一个最终用户应用程序­——至少在生产中。

这意味着当企业需要交付或host一个“pet.com”和“food.com”最终用户应用程序时,通用的生产体系结构就是为每个应用程序提供专用服务器。随着最终应用程序负载需求的增加,水平层在其自身的服务器中被拆分; 但总的来说,一对一的关系仍然存在。

专用服务器

虽然这对于更大、更简单的三层体系结构应用程序来说效果相当好,但是低服务(即每个应用程序的专用服务器)使资源利用率不够优化,扩展速度慢且成本高,因为添加新资源往往需要数天时间,且过量配置硬件资源是缓解处理峰值需求的常见做法。简而言之,那段时间,构建互联网服务是非常昂贵的。

“应用程序虚拟化”(如虚拟主机,Virtual Host)

为了提高服务粒度,大多数基础架构应用程序(如Web服务器和数据库)都提供了一些排序应用程序划分功能,允许一个基础架构应用程序进程支持多个前端应用程序。在Web服务器领域,这称为虚拟主机,其中一个Web服务器可以基于域名服务多个网站。而在数据库领域,单个数据库服务器可以在同一服务器/端口上提供完全隔离的逻辑数据库实例。

这些应用程序虚拟化功能允许企业部署逻辑上隔离的应用程序,或者至少在利用相同的物理资源时提供隔离的错觉。

“应用程序虚拟化”(例如虚拟主机,Virtual Host)

与之前的模型一样,当吞吐量要求增加时,每个水平层都在自己的服务器中拆分,同时仍然为多个应用程序提供服务。某些应用程序(如数据库)开始提供更高级的水平扩展及其群集功能,允许一个逻辑数据库跨越多个资源,从而实现进一步的硬件专业化和更优化的资源利用。

虽然这些技术提高了服务粒度并提高了资源利用率,但却是以软件架构和部署的复杂性为代价的。这增加了复杂性和相互依赖性,使得扩展服务更像是完成一件复杂的艺术品,而不是一个优秀的工程。虽然早期的托管公司确实设法提供网络托管作为服务,但仍没有避免这种复杂性。

换句话说,这断时间,是互联网复杂而脆弱的日子。

虚拟机(Virtual Machine)

随着Linux在服务器上越来越受欢迎,操作系统虚拟化也越来越受欢迎,这使得单个硬件可以托管多个操作系统。使用这种新模型,每个系统或应用程序可以拥有自己的操作系统和环境,同时仍然共享相同的硬件资源。

虚拟机

注:从技术上讲,虚拟机技术是60年代由IBM开创的。但公平地说,Linux(以及Windows,某些情况下)普及了操作系统虚拟化的概念。

这个新模型通过消除系统间的依赖性,最大限度地提高了资源利用率并简化了应用程序架构,恢复了原始形式,但这些新功能带来的最具变革性的结果是由如AWS等驱动的新IT运营模式的形成,此类服务抽象了所有硬件配置和网络复杂性,从而将连接的互联网操作系统作为服务提供。通过这些新的托管或内部部署服务,软件企业可以专注于他们最熟悉的工作: 软件,让少数硬件和网络专家构建并扩展这些服务的主干。

然而,随着托管基础架构服务变得越来越复杂,应用程序开始从传统的三层单块体系结构转向多服务体系结构(如,微服务),以具有成本效益的方式进行设计、部署和管理可扩展的多服务的应用程序变得相对复杂且具有高度特定于云。

容器

业界使用相当古老的Linux功能解决了微服务体系结构的虚拟机模型限制,该功能允许将操作系统进程封装到单个操作系统上的操作系统资源子集中,因此,虚拟化的下一个“章节”,容器化,诞生了,而且主要是由现在几乎无处不在的Docker容器格式占据主流。

有了容器化,应用程序现在可以根据其需求使用最优的服务集进行架构设计,同时相信技术将以最有效的方式划分这些服务。过去在旧的物理硬件中需要几天,在虚拟机中需要几分钟,现在只需要几秒钟,占用的内存非常少(即合理)。

容器

虽然容器化显着改善了服务粒度(即资源利用率),优化了复杂应用程序体系结构并且在开发和生产的过程中规范化了服务运行时,但这些新部件的庞大数量增加了部署管理复杂性和配置挑战。扩展生产系统时,仍然需要特定于云的技术来扩展底层虚拟机,这增加了决定在何处以及何时创建新服务容器的复杂性。

总之,容器化是有帮助的,但它需要其他一些东西来实现真正的价值主张。

Kubernetes

这就是Kubernetes走上舞台并完成这副“拼图”的地方。基于容器,Kubernetes是一种服务(有时称为“引擎”),它提供了一种以标准和环境可移植的方式描述、管理和运行包含其所有部分(即微服务)、交互和伸缩规则的完整系统的方法。

Kubernetes

以前开发、分段和生产环境差别很大,而Kubernetes的新方法规范化并简化了如何描述、运行和扩展整个系统,从而大大降低了构建和管理多服务系统的成本。

重要的是要理解所有这些技术的里程碑,都是演进式和附加式的,并且通常彼此协同使用。从纯粹的技术角度来看,革命是在“进化”而不是在“颠覆”。容器通常在虚拟机上运行,虚拟机仍在物理服务器上的主操作系统(称为主机)上运行,并且许多基础架构应用程序(如数据库,Web服务器和高速缓存)仍提供有用的、且有时是非常关键的、特定于应用程序的群集和分区能力。

将以上所有里程碑式的变化放在一起,我们可以看到所有虚拟化技术是如何附加演进的。

虽然Kubernetes是进化而非颠覆的结果,但其商业价值仍具有变革性。以下是Kubernetes的主要商业价值:

·将Dev规范化为Ops :由于Kubernetes是独立于基础设施的(即它可以在云上、本地部署,甚至在笔记本电脑上运行),它提供了一种非常强大而灵活的方式来规范化开发和运营环境,这可能是实现“高速开发”中最重要的一个方法。

·消除多服务开销 :就在几年前,许多企业开始从整体架构转向微服务架构,而架构迁移确实带来了重大的开发和运营设置阻力。Kubernetes的设计从一开始就致力于以详尽而相对简单的方式解决这些要求,并且只要正确使用,就完全消除了这些开销。

·最大限度地提高云端的可移植性 : Kubernetes最令人印象深刻的成就之一就是在短短几年内掀起了整个行业的风潮,让所有人——从主要的云提供商到混合云技术提供商,都争相在新标准中加入支持。这使得Kubernetes成为云端可移植性的基石,并允许大多数现代云应用可以表达其系统的80%到90%,并且能够以云可移植的方式进行可伸缩性拓扑。

·简化和标准化可扩展性 :云可移植性的部分价值在于对通用和自定义伸缩规则进行标准化,这些规则使多服务系统的伸缩按指数级简化,同时在需要时仍然能够进行定制化。

笔者通常会以非常谨慎的态度对待最新的技术,因为它们虽然感到兴奋,但往往是相对短暂的。不过,Kubernetes是少数几个被巩固为Linux、OS虚拟化和Git等基础技术的技术之一因为它确实能带来看得见的价值。简而言之,Kubernetes可能是对于当今任何云应用程序开发企业而言最安全的投资,如果运用得当,它可以显著提高开发和交付的速度和质量。

原文来源:Medium 作者:Jeremy Chone

原文链接:https://blog.britesnow.com/understanding-kubernetes-value-867c163d5ed2

从虚拟主机时代说起,详述Kubernetes带来的变革相关推荐

  1. 虚拟主机时代:美国主机如何在国内显神通

    虚拟主机技术的出现不仅对Internet技术带来重大贡献,更是广大网站爱好者的福音.伴随着互联网在国内的普及,中国互联网产业越来越显现出其无限的潜力,美国虚拟主机商目光也越来越聚集到中国这块黄金市场上 ...

  2. 云服务器和虚拟主机和VPS都是什么意思?到底有啥区别呢?

    我们公司最近打算上线部署一款客户管理系统需要租一个服务器.结果在选购时,还是纠结了好久,不知道要买云服务器还是虚拟主机.更搞不清楚云服务器,虚拟主机,VPS都是什么意思,到底之间有啥区别呢? 最后查了 ...

  3. 云计算时代,建站选择虚拟主机还是云服务器

    你在考虑用虚拟主机还是云服务器? 你只是想运行网站吧. 看完这篇文章也许你就不纠结了? 虚拟主机是web时代的元老了,国内外提供虚拟主机服务的商家也是数不清.虚拟主机的作用是存放数据和传输数据,其中最 ...

  4. 【云计算的1024种玩法】回忆经典,用虚拟主机重建复古DZ和无心宠物

    前言 在移动互联网和大型网游没有普及前,很多地方论坛或者专业性论坛都会有一个 -- "无心宠物" 插件来引流和吸引用户,可以说是当下网页游戏的老前辈了.还记得我以前就是为了玩这个游 ...

  5. 虚拟主机传奇服务器,虚拟主机市场迅猛发展 演绎网络产品传奇

    随着互联网持续快速增长,网络规模迅速扩大,企业信息化进程不断提速.截止2010年,中国网民的数量规模为4.2亿人,预计到2011年中国网民的数量规模将达到5亿人,中小企业也必将意识到建立企业网站,进行 ...

  6. 威联通架设php网站_使用QNAP NAS虚拟主机功能架设多个网站

    在这个网络营销活动活跃的时代,在网络上拥有一个与产品使用者及客户的互动园地是非常重要的.随着越来越多的免付费资源出现于网络上,架设网站不仅不需要专业人员,更可能是只要点几下鼠标就能完成的简单任务. 虚 ...

  7. 金泰联限量稳定虚拟主机赞助计划

    中国互联网正处于蓬勃发展的阶段,又是"大众创业.万众创新"遇上"互联网+"这个时代最活跃元素的一年,借助这种强大的火花,促进了整个IDC市场的趋势健康发展.作为 ...

  8. 服务器虚拟主机划分,服务器划分虚拟主机教程

    服务器划分虚拟主机教程 内容精选 换一换 本最佳实践模拟使用L2CG服务,构建华为云上两个Region内子网的大二层网络.按照主机粒度迁移.迁移过程中不中断业务.保持私有IP不变.此最佳实践描述的网络 ...

  9. ipv6 服务器虚拟机软件,ipv6虚拟主机是做什么的

    原标题:ipv6虚拟主机是做什么的 ipv6虚拟主机是做什么的? IPv6虚拟主机就是支持IPv6网络访问的虚拟主机产品.可避免ipv6网络用户访问障碍的问题. ipv6 目前,市面上可提供支持IPv ...

最新文章

  1. Linux下安装Tomcat
  2. Docker中的“公开”和“发布”有什么区别?
  3. linux tcp阻塞socket recv接收数据 未达到指定长度返回问题
  4. PyTorch 实现经典模型1:LeNet5
  5. ssl1344-Knights【最大独立集,最大匹配,图论】
  6. 1 FI配置-企业结构-定义-创建集团公司(Company)
  7. ElasticSearch面试 - es 生产集群的部署架构是什么?
  8. java 抽象接口_JAVA中的“抽象接口”
  9. vsftp pam mysql_实验记录:vsftp整合mysql-pam管理虚拟账号
  10. ssas 维度属性_Analysis Services(SSAS)多维数据集–维度属性和层次结构
  11. shiro 30分钟未操作_大道至简:请笑纳股票精华知识:30分钟k线操作,用最简单的超短线炒股方法赚大钱!...
  12. 超简单Python画Heatmap-热力图 -plotly库
  13. Jenkins Xcode打包ipa
  14. ITIL服务管理知识体系的介绍
  15. 电子标签有哪些封装方式
  16. 读《PROSOSPEECH: ENHANCING PROSODY WITH QUANTIZED VECTOR PRE-TRAINING IN TEXT-TO-SPEECH》
  17. Spring Boot 导出EXCEL模板以及导入EXCEL数据(阿里Easy Excel实战)
  18. 八款android日历 [Calendar] 开源项目框架分类总汇
  19. java 雷达反射面积_请问:如何使用基本反射率雷达图中的dBZ值判断天气情况?比如多云、雷雨、晴等。谢谢!...
  20. VideoSolo Blu ray Player for Mac(mac蓝光播放器)

热门文章

  1. linux驱动基础开发1——linux 设备驱动基本概念-转
  2. LeetCode 78. Subsets
  3. 【note】《软件体系结构》知识整理(1-5章)
  4. 【操作系统】进程的异步性
  5. Spring Cloud Zuul--服务网关
  6. demo16 webpack 处理字体
  7. JavaWeb初学者session的使用
  8. js如何判断访问来源是来自搜索引擎(蜘蛛人)还是直接访问
  9. 大道至简——编程的精义
  10. 软件过程评估和软件能力评价的方法与步骤