搜索引擎优化

田柯:什么是cloud Native ?

什么是cloud Native

cloud Native就是云原生!

云原生是什么?这个众说纷纭,没有统一的定义,姑且以老大哥CNCF的定义来了解云原生。

老大哥?CNCF?

25cb93a2f3dc4190a6f5b248d46c16fe?from=pc - 田柯:什么是cloud Native ?

CNCF,全称为Cloud Native Computing Foundation,中文译为“云原生计算基金会”。成立于2015年12月11日,CNCF是Linux基金会旗下的基金会。CNCF致力于培育和维护一个厂商中立的开源生态系统,来推广云原生技术。CNCF是云原生领域影响力最大最有话语权的组织。

06b93aab1cb1431e85c4aabeb52e2346?from=pc - 田柯:什么是cloud Native ?

说起CNCF的故事,还要从Cgroups(control groups,控制组群)开始说起,时间轴回到16年前。

2004年,谷歌开始使用容器技术,于2006年发布了Cgroups,最初叫Process Container(进程容器)。

Process Container的目的非常直白,它希望能够像虚拟化技术那样给进程提供操作系统级别的资源限制、优先级控制、资源审计能力和进程控制能力。带着这样的设计思路,Process Container在2006年由Google的工程师正式推出后,第二年就进入了Linux内核主干。

因为在Linux内核中,容器(container)这个名词有许多不同的意义,为避免混乱,就更名为Control Groups,也就是Cgroups。

2013 年,Docker 项目正式发布,2014 年,K8s项目也正式发布。

原因非常容易理解,因为有了容器和 Docker 之后,就需要有一种方式去帮助大家方便、快速、优雅地管理这些容器,这就是K8s项目的初衷。

K8s是云原生的基石,后面会细讲。在 Google 和 Redhat 发布了K8s 之后,这个项目的发展速度非常之快。

2015 年,由Google、Redhat 以及微软等大型云计算厂商以及一些开源公司共同牵头成立了 CNCF 云原生基金会。CNCF成立之初,就有22个创始会员,而且K8s也成为了 CNCF 托管的第一个开源项目。

a43d8569c94f403c8ac4e1ba59cc89ea?from=pc - 田柯:什么是cloud Native ?

在这之后,CNCF 迅猛发展。截止2020年2月,从官网看到数据显示有433个会员。

d70ca1579cba41ac94e2175f170af3d0?from=pc - 田柯:什么是cloud Native ?

那么CNCF是如何定义云原生的呢?

70ba4985f048441e8d79ad689a2dac4e?from=pc - 田柯:什么是cloud Native ?

翻译为中文:


云原生技术有利于各组织在公有云、私有云和混合云等新型动态环境中,构建和运行可弹性扩展的应用。云原生的代表技术包括容器、服务网格、微服务、不可变基础设施和声明式API。这些技术能够构建容错性好、易于管理和便于观察的松耦合系统。结合可靠的自动化手段,云原生技术使工程师能够轻松地对系统作出频繁和可预测的重大变更。 云原生计算基金会(CNCF)致力于培育和维护一个厂商中立的开源生态系统,来推广云原生技术。我们通过将最前沿的模式民主化,让这些创新为大众所用。

除了CNCF关于云原生的定义,网络上流传的另一个版本是Pivotal 公司的 Matt Stine于2013年首次提出云原生概念;2015年,云原生刚推广时,Matt Stine在《迁移到云原生架构》一书中定义了符合云原生架构的几个特征:12因素、微服务、自敏捷架构、基于API 协作、扛脆弱性。

到了2017年,Matt Stine 改了口风,将云原生架构归纳为模块化、可观察、可部署、可测试、可替换、可处理6特质;而Pivotal 官网对云原生概括为4个要点:DevOps+持续交付+微服务+容器。39190aa248e04e949b6913a1102ec723?from=pc - 田柯:什么是cloud Native ?

云原生所需能力与特征 by:CNCF大使 宋净超

MattStine认为云原生它是一个思想的集合,包括DevOps、持续交付(Continuous Delivery)、微服务(MicroServices)、敏捷基础设施(Agile Infrastructure)、康威定律(Conways Law)等。

云原生即包含技术(微服务,敏捷基础设施),也包含管理(DevOps,持续交付,康威定律,重组等)。云原生也可以说是一系列云技术、企业管理方法的集合。

我们以CNCF官方的定义来接着了解。云原生的代表技术包括容器、服务网格、微服务、不可变基础设施和声明式API。那么这些技术都是什么?这些技术有什么联系?

◆◆云原生代表技术◆◆

容器

一般我们说的“容器”(LinuxContainer,LXC),都是“Linux容器”(当然微软也在搞容器,但还没linux那么成熟)。开源解决方案供应商红帽官网给出的容器定义:


Linux® 容器是与系统其他部分隔离开的一系列进程。运行这些进程所需的所有文件都由另一个镜像提供,这意味着从开发到测试再到生产的整个过程中,Linux 容器都具有可移植性和一致性。因而,相对于依赖重复传统测试环境的开发渠道,容器的运行速度要快得多。容器比较普遍也易于使用,因此也成了 IT 安全方面的重要组成部分。

容器提供进程级的隔离,可以将操作系统管理的资源划分到相互隔离的组中,在相互隔离的组之间解决资源使用存在冲突的问题。比如应用程序(Application,APP )APP 1 只能在centos 操作系统上运行,APP2只能在ubuntu操作系统上运行,而同一个操作系统同时运行APP1和APP2就产生冲突,容器技术则恰恰可以解决这类问题。目前主流的容器技术有Docker、LXD以及RKT等。

Docker

说到容器,就不得不说Docker。

2010年,几个大胡子的年轻人在美国旧金山成立了一家名叫“dotCloud”的公司。这家公司主要提供基于PaaS的云计算技术服务。具体来说,是和LXC有关的容器技术。LXC,就是Linux容器虚拟技术(Linux container)

992f0c17825b436ca70cd1fc6fab1b33?from=pc - 田柯:什么是cloud Native ?

后来,dotCloud公司将自己的容器技术进行了简化和标准化,并命名为——Docker。

Docker项目发布时,无非也是LXC的一个使用者,它创建和使用应用容器的逻辑跟Warden等竞争对手没有本质不同。不过,我们现在也知道,真正让PaaS项目无所适从的,是Docker项目最厉害的杀手锏:容器镜像。

Docker项目通过容器镜像,直接将一个应用运行所需的完整环境,即:整个操作系统的文件系统也打包了进去。这种思路,可算是解决了困扰PaaS用户已久的一致性问题,制作一个“一次发布、随处运行”的Docker镜像的意义,一下子就比制作一个连开发和测试环境都无法统一的Buildpack高明了太多。

Docker项目大大降低了容器技术的使用门槛,轻量级,可移植,虚拟化,语言无关,写了程序扔上去做成镜像可以随处部署和运行,开发、测试和生产环境彻底统一了,还能进行资源管控和虚拟化。

Docker作为一种开源应用容器引擎,是为开发人员和系统管理员设计的用于构建、发布和运行分布式应用的平台,典型的Docker平台Kubernetes、Openshift V3、Flynn、Deis等。

Docker允许开发人员将各种应用以及依赖包打包到一个可移植的Docker容器中,以Docker容器为资源分割和调度的基本单位,封装整个软件运行时的环境,然后发布到Linux机器上。

6d1a8f990047464aba4488271afa1825?from=pc - 田柯:什么是cloud Native ?

Docker设计原理如上图所示。按照Docker的设计方案,应用软件的交付过程如同海上运输,操作系统OS如同一个货轮,每一个在OS基础上的软件都如同一个集装箱,用户可以通过标准化手段自由组装运行环境,同时集装箱的内容可以由用户自定义,也可以由专业人员(开发人员或系统管理员)定制,如此一来,交付一个应用软件产品,就相当于交付一系列标准化组件的集合。

一句话解释Docker?

没有集装箱就没有全球化,Docker就是IT世界里的集装箱。

有了容器,就需要编排管理容器的生命周期,kubernetes要了解一下。

Kubernetes

说一下kubernetes,kubernetes一度被大家称为云原生的基石。

bdce35bf51df4264824d196de05581ca?from=pc - 田柯:什么是cloud Native ?

K8s,全称是Kubernetes。这个单词来自于希腊语,含义是舵手或领航员。K8s是它的缩写,用“8”字替代了“ubernete”这8个字符。

K8s并不是一件全新的发明。它是谷歌根据其内部使用的 Borg 改造成的一个通用容器编排调度器,于2014年6月开源,同年7月,微软、Red Hat、IBM、Docker等公司,相继加入K8s。2015年,谷歌将其捐赠给 Linux 基金会下属的云原生计算基金会(CNCF),K8s也成为CNCF第一个项目。

K8s的架构,略微有一点复杂,我们简单来看一下。

3cce35eb9bad446bb0c89f0ddf53ab11?from=pc - 田柯:什么是cloud Native ?

一个K8s系统,通常称为一个K8s集群(Cluster)。这个集群主要包括两个部分:一个Master节点(主节点)和一群Node节点(计算节点)。

列举下一些专用术语的解释。

Master(主节点):控制 K8s 节点的机器,也是创建作业任务的地方。

Node(节点):这些机器在 K8s 主节点的控制下执行被分配的任务。

Pod:由一个或多个容器构成的集合,作为一个整体被部署到一个单一节点。同一个 pod 中的容器共享 IP 地址、进程间通讯(IPC)、主机名以及其它资源。Pod 将底层容器的网络和存储抽象出来,使得集群内的容器迁移更为便捷。

Replicationcontroller(复制控制器):控制一个 pod 在集群上运行的实例数量。

Service(服务):将服务内容与具体的 pod 分离。Kubernetes服务代理负责自动将服务请求分发到正确的 pod 处,不管 pod 移动到集群中的什么位置,甚至可以被替换掉。

Kubelet:这个守护进程运行在各个工作节点上,负责获取容器列表,保证被声明的容器已经启动并且正常运行。
kubectl: 这是 Kubernetes 的命令行配置工具。

理解完K8s 部分专业术语,就大致对K8s有个了解了。

云可以为我们提供稳定而唾手可得的基础设施,但是业务上云成了一个难题,K8s 的出现与其说是从最初的容器编排解决方案开始,倒不如说是为了解决应用上云(即云原生应用)这个难题。

CNCF 中托管的一系列项目即致力于云原生应用整个生命周期的管理,从部署平台、日志收集、Service Mesh(服务网格)、服务发现、分布式追踪、监控以及安全等各个领域通过开源软件为我们提供一整套解决方案。

Google 通过将云应用进行抽象简化出的 Kubernetes 中的各种概念对象,如Pod、Deployment、Job、StatefulSet 等,形成了Cloud Native 应用的通用可移植的模型,Kubernetes 作为云应用的部署标准,直接面向业务应用,大大提高了云应用的可移植性,解决云厂商锁定的问题,让云应用可以在夸云之间无缝迁移,甚至用来管理混合云,成为企业 IT 云平台的新标准。

微服务

在介绍微服务时,首先得先理解什么是微服务,顾名思义,微服务得从两个方面去理解,什么是”微”、什么是”服务”,微 狭义来讲就是体积小、著名的 “2 pizza 团队” 很好的诠释了这一解释(2 pizza 团队最早是亚马逊 CEO Bezos提出来的,意思是说单个服务的设计,所有参与人从设计、开发、测试、运维所有人加起来只需要2个披萨就够了)。

873d9c1032f74df68022e6a5063a3e36?from=pc - 田柯:什么是cloud Native ?

而所谓服务,一定要区别于系统,服务一个或者一组相对较小且独立的功能单元,是用户可以感知最小功能集。

传统的单体架构是以整个系统为单位进行部署,而微服务则是以每一个独立组件(例如用户服务,商品服务)为单位进行部署。对于单体应用,如果发现某一业务的请求量非常大,那么是无法单独扩展该业务的,只能拷贝整个单体应用,再部署一套环境,来实现集群。正因为单体应用的缺陷,才有了微服务。

微服务和单体应用的区别,可以用Martin Fowler的这张图来解释:3c79486f3b9c45e38cd6cf537995be5f?from=pc - 田柯:什么是cloud Native ?

图中左边是单体架构的集群,右边是微服务集群。

什么意思呢?比如根据每个服务的吞吐量不同,支付服务需要部署20台机器,用户服务需要部署30台机器,而商品服务只需要部署10台机器。这种灵活部署只有微服务架构才能实现。

而近几年流行的Docker,为微服务架构提供了有效的容器。

服务网格

服务网格( Service Mesh )是指用以处理服务与服务之间通信的基础设施层。其最早由Buoyant公司(开发Service Mesh项目Linkerd的公司)提出,并在内部使用。该公司2016年9月29日第一次公开使用这个术语。

Service Mesh一般用于微服务应用的可配置基础架构层( configurable infrastructure layer )。Istio( 由Google、IBM、Lyft公司在背后进行支持 ) 是目前最广为人知的一款服务网格架构。

facd1e78f78d4087a79dfd7b84fb1d34?from=pc - 田柯:什么是cloud Native ?

Kubernetes(由Google最早进行设计并开源)是目前Istio唯一支持的容器组织框架。

为什么Service Mesh这么受欢迎?对许多公司来说,Docker 和 Kubernetes 这样的工具已经 “解决了部署问题”,或者说几乎解决了。但他们还没有解决运行时的问题,这就是服务网格的由来。

什么是解决了部署问题?使用 Docker 和 Kubernetes 等功能可显著减轻部署的增量操作负担。使用这些工具,部署100个应用或服务不再是部署单个应用的100倍。这是向前迈出的一大步,对许多公司来说,这导致采用微服务的成本大幅降低。这不仅是因为 Docker 和 Kubernetes 所提供了强大的抽象,而且还因为它们使整个组织的打包和部署模式过程标准化了。

Service Mesh的出现,弥补了Kubernetes在微服务的连接、管理和监控方面的短板,为Kubernetes提供更好的应用和服务管理。因此,Service Mesh的代表Istio一经推出,就被认为是可以和Kubernetes形成双剑合璧效果的微服务管理的利器,受到了业界的推崇。

不可变基础设施

在传统的可变服务器基础架构中,服务器会不断更新和修改。使用此类基础架构的工程师和管理员可以通过SSH连接到他们的服务器,手动升级或降级软件包,逐个服务器地调整配置文件,以及将新代码直接部署到现有服务器上。换句话说,这些服务器是可变的;它们可以在创建后进行更改。

可变基础设施通常会导致以下问题:

在灾难发生的时候,难以重新构建服务。持续过多的手工操作,缺乏记录,会导致很难由标准初始化后的服务器来重新构建起等效的服务。
在服务运行过程中,持续的修改服务器,就犹如程序中的可变变量的值发生变化而引入的状态不一致的并发风险。这些对于服务器的修改,同样会引入中间状态,从而导致不可预知的问题。

不可变基础架构是另一种基础架构范例,其中服务器在部署后永远不会被修改。程序设计中不可变变量(ImmutableVariable)就是在完成赋值后就不能发生更改,只能创建新的来整体替换旧的。由于具有这样的特性这种变量可以在并发环境下安全的使用。对于基础设施的不可变性,最基本的就是指运行服务的服务器在完成部署后,就不在进行更改。

不可变基础架构的好处包括基础架构中更高的一致性和可靠性,以及更简单,更可预测的部署过程。

它可以缓解或完全防止可变基础架构中常见的问题,例如配置漂移和雪花服务器。但是,有效地使用它通常包括全面的部署自动化,云计算环境中的快速服务器配置,以及处理状态或短暂数据(如日志)的解决方案。

声明式API

声明式(Declarative)的编程方式一直都会被工程师们拿来与命令式(Imperative)进行对比,这两者是完全不同的编程方法。

我们最常接触的其实是命令式编程,它要求我们描述为了达到某一个效果或者目标所需要完成的指令,常见的编程语言 Go、Ruby、C++ 其实都为开发者了命令式的编程方法,

声明式和命令式是两种截然不同的编程方式:

在命令式 API 中,我们可以直接发出服务器要执行的命令,例如: “运行容器”、“停止容器”等;
在声明式 API 中,我们声明系统要执行的操作,系统将不断向该状态驱动。

通俗的说,命令式编程是第一人称,我要做什么,我要怎么做。 操作系统最喜欢这种编程范式了, 操作系统几乎不用”思考”, 只要一对一的将代码翻译成指令就可以了。 而声明式编程则类似于”第二人称”, 也就是你要做什么。 有点”产品经理”和”开发“之间的关系,”产品经理”只负责提需求,而”开发”怎么实现他不并关心。

让我们来总结一下上面提到的技术和工具。

k8s是整个云原生的基石,云原生的整个生态体系都是依靠k8s建立起来的。 容器(Container)是k8s的底层引擎; Docker是应用最广的容器工具; 微服务是docker的好搭档; 服务网格是微服务的辅助,建立在k8s上的针对请求的扩展功能; 不可变基础设施是现代运维的基石; 声明式API是k8s的编码方式;

◆◆云原生应用价值◆◆

由于篇幅关系,简单列举三项云原生应用价值。

1)快速迭代

利用云原生应用程序开发,意味着使用敏捷与可扩展的组件,如以Kubernetes为代表的容器来提供离散和可重用的功能,这些功能以良好描述的方式集成,甚至跨越多云等技术边界,这使得交付团队可以使用重复的自动化和编排来快速迭代。

2)自动部署

云原生方法远优于传统的面向虚拟化的业务流程,传统方法需要投入大量的精力来构建开发环境,以及软件交付过程中的其他不同环境。而云原生架构具备自动化和组合功能,并且依赖于可靠、经过验证和审核的已知良好流程的基础,交付十分敏捷,而不再需要人工干预重复执行。

3)独立高效

云原生带来了微服务化架构,一个微服务基本是一个能独立发布的应用服务,因此可以作为独立组件升级、灰度或复用等,对整个大应用的影响也较小,每个服务可以由专门的组织来单独完成,依赖方只要定好输入和输出口即可完全开发、甚至整个团队的组织架构也会更精简,因此沟通成本低、效率高。

谈云原生就要谈云计算,不和云计算对比都是耍流氓。云计算的第一个浪潮是关于成本节约和业务敏捷性,尤其是云计算的基础设施更加廉价。

很多企业倾向于使用微服务架构来开发应用。微服务开发快速,职责单一,能够更快速的被客户所采纳。同时,这些应用能够通过快速迭代的方式,得到进化,赢得客户的认可。云原生可以打通微服务开发、测试、部署、发布的整个流程环节。

云供应商为迎合市场,提供了满足各种场景方案的 API,例如用于定位的 Google Maps,用于社交协作的认证平台等。将所有这些 API 与企业业务的特性和功能混合在一起,可以让他们为客户构建独特的方案。所有这些整合都在 API 层面进行。这意味着,不管是移动应用还是传统的桌面应用都能无缝集成。所以,采用云原生所开发的应用都且具备极强的可扩展性。

软件不可能不出故障。传统的企业级开发方式,需要有专职人员来对企业应用进行监控与维护。而在云原生架构下,底层的服务或者是API都由将部署到云中,等价于将繁重的运维工作转移给了云平台供应商。这意味着客户应用将得到更加专业的看护,同时,也节省了运维成本。

d809e799a5f34de3a29779261edf0fe7?from=pc - 田柯:什么是cloud Native ?

“大鱼”来了,我们能做的不是墨守成规,而是拥抱“大鱼”,时代在召唤云原生,但是云原生不是一蹴而就,而是有个循序渐进的过程。排斥云原生,了解云原生,拥抱云原生,追随云原生。

云原生技术有利于各组织在公有云、私有云和混合云等新型动态环境中,构建和运行可弹性扩展的应用。


云原生的代表技术包括容器、服务网格、微服务、不可变基础设施和声明式API。这些技术能够构建容错性好、易于管理和便于观察的松耦合系统。

结合可靠的自动化手段,云原生技术使工程师能够轻松对系统做出频繁和可预测的重大变更。

云原生计算基金会(CNCF)致力于培育和维护一个厂商中立的开源生态系统,来推广云原生技术。

我们通过将最前沿的模式民主化,让这些创新为大众所用。

Cloud Native technologies empower organizations to build and run scalable applications in modern, dynamic environments such as public, private, and hybrid clouds.

Containers, service meshes, microservices, immutable infrastructure, and declarative APIs exemplify this approach. These techniques enable loosely coupled systems that are resilient, manageable, and observable.

Combined with robust automation, they allow engineers to make high-impact changes frequently and predictably with minimal toil.

The Cloud Native Computing Foundation seeks to drive adoption of this paradigm by fostering and sustaining an ecosystem of open source, vendor-neutral projects.

We democratize state-of-the-art patterns to make these innovations accessible for everyone.

CNCF认为CloudNative系统需包含的属性:

(a) 容器化封装:以容器为基础,提高整体开发水平,形成代码和组件重用,简化云原生应用程序的维护。在容器中运行应用程序和进程,并作为应用程序部署的独立单元,实现高水平资源隔离。

(b) 自动化管理:统一调度和管理中心,从根本上提高系统和资源利用率,同时降低运维成本。

(c) 面向微服务:通过松耦合方式,提升应用程序的整体敏捷性和可维护性。

1410bd0d70854a07887ccf009c8f8e9b?from=pc - 田柯:什么是cloud Native ?

Pivotal最初的定义

Pivotal 是云原生应用的提出者,并推出了Pivotal Cloud Foundry 云原生应用平台和 Spring 开源 Java 开发框架,成为云原生应用架构中先驱者和探路者。早在2015年Pivotal公司的Matt Stine写了一本叫做迁移到云原生应用架构的小册子,其中探讨了云原生应用架构的几个主要特征:

符合12因素应用

面向微服务架构

自服务敏捷架构

基于API的协作

抗脆弱性

CNCF最初的定义

到了2015年Google主导成立了云原生计算基金会(CNCF),起初CNCF对云原生(Cloud Native)的定义包含以下三个方面:

应用容器化

面向微服务架构

应用支持容器的编排调度

云原生的重新定义

到了2018年,随着近几年来云原生生态的不断壮大,所有主流云计算供应商都加入了该基金会,且从Cloud Native Landscape中可以看出云原生有意蚕食原先非云原生应用的部分。CNCF基金会中的会员以及容纳的项目越来越多,该定义已经限制了云原生生态的发展,CNCF为云原生进行了重新定位。以下是CNCF对云原生的重新定义(中英对照):

Cloud native technologies empower organizations to build and run scalable applications in modern, dynamic environments such as public, private, and hybrid clouds. Containers, service meshes, microservices, immutable infrastructure, and declarative APIs exemplify this approach.

(云原生技术有利于各组织在公有云、私有云和混合云等新型动态环境中,构建和运行可弹性扩展的应用。云原生的代表技术包括容器、服务网格、微服务、不可变基础设施和声明式API。)

These techniques enable loosely coupled systems that are resilient, manageable, and observable. Combined with robust automation, they allow engineers to make high-impact changes frequently and predictably with minimal toil.

(这些技术能够构建容错性好、易于管理和便于观察的松耦合系统。结合可靠的自动化手段,云原生技术使工程师能够轻松地对系统作出频繁和可预测的重大变更。)

The Cloud Native Computing Foundation seeks to drive adoption of this paradigm by fostering and sustaining an ecosystem of open source, vendor-neutral projects. We democratize state-of-the-art patterns to make these innovations accessible for everyone.

(云原生计算基金会(CNCF)致力于培育和维护一个厂商中立的开源生态系统,来推广云原生技术。我们通过将最前沿的模式民主化,让这些创新为大众所用。)

下图为其公布的Cloud Native Landscape,给出了云原生生态的参考体系。

88013728623c4e3a8368a24b22874aeb?from=pc - 田柯:什么是cloud Native ?

云原生 = 微服务 + DevOps + 持续交付 + 容器化

微服务技术使得应用原子化,所有的应用都可以独立的部署、迭代。

DevOps使得应用可以快速编译、自动化测试、部署、发布、回滚,让开发和运维一体化。

持续交付让应用可以频繁发布、快速交付、快速反馈、降低发布风险。

容器使得应用整体开发以容器为基础,形成代码组件复用、资源隔离。

93a5b032f8934de592dc1374427c7fd5?from=pc - 田柯:什么是cloud Native ?

相比于传统应用,云原生应用意味着统一:

统一的技术标准:通常以微服务架构进行服务开发,服务之间使用标准的API契约进行通信。松耦合的架构方式会减轻因需求变更导致的系统迭代成本,并加快交付速度。

微服务倡导基于API接口通信,避免在服务间共享数据库,文件等有状态的实体。单个服务能独立的更新,扩展,重启而不影响其他服务。

微服务使得单个服务的开发团队更小,也更加独立。亚马逊内部采取2个披萨原则——即团队规模维持在刚好两个披萨能够吃饱,来限定团队规模。团队沟通成本可以维持在较低水平, 同时每个人都承担富有挑战性的工作。

松耦合+独立小型的团队使得持续更新和敏捷管理协作成为可能,因此微服务成为了云原生应 用的最佳开发实践之一。

统一的交付方式:标准容器化的打包方式实现了真正的应用可移植性,不依赖于特定的基础架构(虚拟机,混合云等)。

容器技术起源于linux的进程隔离虚拟化技术,将一组进程单独限定在同一个资源目录下,并可以限定其资源使用的配额。

Docker的出现将应用的整个运行时环境都打包成一个镜像文件,并基于容器本身的隔离特性,实现了应用在特定容器中可以轻松的在不同环境间移植,同时确保宿主机的安全。

在资源有限的场景,容器基于进程粒度的资源使用方式,也会降低系统的资源开销。

基于容器的应用将有助于构建统一的开发,交付和集成环境,是云原生应用的最佳交付载体。

统一的运维部署:基于容器的编排平台,可以充分利用不可变基础设施的特性。这使得在传统运维模式中的复杂部署策略(如灰度,蓝绿)变得轻而易举。

容器编排平台提供的自动化运维特性和声明式资源管理方式简化了持续构建中工具链之间的协作和调度。

容器编排带来的弹性伸缩能力和容错调度能力也让智能化运维成为可能。

技术驱动下的敏捷协作,和编排平台带来的运维能力共同构建了云原生应用的最佳运维实践——DevOps

总结:时代在召唤云原生,但是云原生不是一蹴而就,而是有个循序渐进的过程!它就像做网站关键词排名,一分耕耘一分收获!


我是田柯, 专注于百度,微信平台的精准引流,如果你有相关问题或者需求,可以扫码找到我

1 5 - 田柯:什么是cloud Native ?

欢迎转载,转载请说明出处

文章来源:田柯博客