所属章节:
第14章. 云原生架构设计理论与实践
第1节 云原生架构产生背景
云原生(Cloud Native) 是近几年云计算领域 炙手可热的话题,云原生技术已成为驱动业务增长的重要引擎 。同时,作为新型基础设施的重要支撑技术 ,云原生也逐渐在人工智能、大数据、边缘计算、5G等新兴领域崭露头角。伴随着各行业上云的逐步深化,云原生转型进程将进一步加速。本章主要介绍了云原生背景、定义、架构以及相关云原生技术等方面知识。
14.1 云原生架构产生背景
"云原生"来自于"Cloud Native"的直译,拆开来看,Cloud就是指其应用软件是在云端而非传统的数据中心 ;Native代表应用软件从一开始就是基于云环境、专门为云端特性而设计 ,可充分利用和发挥云平台的弹性 + 分布式优势,最大化释放云计算生产力。
对于原来的企业而言,企业内部IT建设以"烟筒"模式比较多,每个部门甚至每个应用都相对独立,如何管理与分配资源成了难题。大都数都基于最底层IDC设施独自向上构建,需要单独分配硬件资源,这就造成资源被大量占用且难以被共享。但是上云之后,由于云厂商提供了统一的IaaS能力和云服务,大幅提升了企业Iaas层的复用程度,CIO或者It主管自然而然想到IaaS以上层的系统也需要被统一,使资源、产品可被不断复用,从而能够进一步降低企业运营成本。
对于开发而言,传统的IT架构方式,将开发、IT运营和质量保障分别设置,各自独立 ,开发与运营之间存在着信息"鸿沟",开发人员希望基础设施更快响应,运营人员则要求系统的可靠性和安全性,而业务需求则是更快地将更多的特性发布给最终用户使用。这种模式被称为"瀑布式"流程的开发模式,一方面造成了开发上下游的信息不对称,一方面拉长了开发周期和调整难度 。但是随着用户需求的快速增加和产品迭代周期的不断压缩,原有的开发流程不再适合现实的需求,这时工程师们引入了一种新的开发模式------敏捷开发。但是,敏捷开发只是解决了软件开发的效率和版本更新的速度,还没有和运维打通。出于协调开发和运维的"信息对称"问题,开发者又推出了一套新的方法------DevOps。DevOps可以看作是开发、技术运营和质量保障三者的交集 ,促进之间的沟通、协作与整合,从而提高开发周期和效率 。而云原生的容器、微服务等技术 正是为DevelopOps提供了很好的前提条件,保证IT软件开发实现DevOps开发和持续交付的关键应用 。换句话说,能够实现DevOps和持续交付,已经成为云原生技术价值不可分割的内涵部分,这也是无论互联网巨头企业、还是众多中小应用开发公司和个人,越来越多选择云原生技术和工具的原因。
这里进行一下DevOps的相关内容(以下内容引自百度百科):
1. 概述
DevOps(Development和Operations的组合词)是一组过程、方法与系统的统称 ,用于促进开发 (应用程序/软件工程)、技术运营 和质量保障 (QA)部门之间的沟通、协作与整合。
DevOps是一种重视"软件开发人员(Dev)"和"IT运维技术人员(Ops)"之间沟通合作的文化、运动或惯例。透过自动化"软件交付"和"架构变更"的流程,来使得构建、测试、发布软件能够更加地快捷、频繁和可靠。
DevOps的出现是由于软件行业日益清晰地认识到:为了按时交付软件产品和服务,开发和运维工作必须紧密合作。
2. 详述
DevOps是Development和Operations的组合,是开发和运营维护的总称。软件设计过程中,应对开发部门、运维部门进行协调,确保各项工作流程与方法高效使用,为项目管理工作提供可靠参考。基于devops软件开发源于2009年欧洲传统IT模式,对解决运维管理问题起到关键作用。为巩固软件设计与开发结果,将开发、运维与测试结合一起,形成了DevOps软件开发管理模式。
基于DevOps软件开发可对测试环境进行应用,同时可将数据包融入到软件环境中。DevOps立足全局角度,对开发效果进行分析,加强人员之间的合作与交流也是软件开发设计工作重点,应对其进行合理安排。在devops框架下,对软件进行开发可实现自动化操作,使得人机交互方案应用具有可行性。
传统的软件组织将开发、IT运营和质量保障设为各自分离的部门。在这种环境下如何采用新的开发方法(例如敏捷软件开发),这是一个重要的课题:按照从前的工作方式,开发和部署不需要IT支持或者QA深入的、跨部门的支持,而却需要极其紧密的多部门协作。然而DevOps考虑的还不止是软件部署。它是一套针对这几个部门间沟通与协作问题的流程和方法。
需要频繁交付的企业可能更需要对DevOps有一个大致的了解。Flickr发展了自己的DevOps能力,使之能够支撑业务部门"每天部署10次"的要求──如果一个组织要生产面向多种用户、具备多样功能的应用程序,其部署周期必然会很短。这种能力也被称为持续部署,并且经常与精益创业方法联系起来。 从2009年起,相关的工作组、专业组织和博客快速涌现。
DevOps的引入能对产品交付、测试、功能开发和维护(包括──曾经罕见但如今已屡见不鲜的──"热补丁")起到意义深远的影响。在缺乏DevOps能力的组织中,开发与运营之间存在着信息"鸿沟"──例如运营人员要求更好的可靠性和安全性,开发人员则希望基础设施响应更快,而业务用户的需求则是更快地将更多的特性发布给最终用户使用。这种信息鸿沟就是最常出问题的地方。
以下几方面因素可能促使一个组织引入DevOps:
1、使用敏捷或其他软件开发过程与方法
2、业务负责人要求加快产品交付的速率
3、虚拟化和云计算基础设施(可能来自内部或外部供应商)日益普遍
5、有一种观点认为,占主导地位的"传统"美国式管理风格("斯隆模型 vs 丰田模型")会导致"烟囱式自动化",从而造成开发与运营之间的鸿沟,因此需要DevOps能力来克服由此引发的问题。
DevOps经常被描述为"开发团队与运营团队之间更具协作性、更高效的关系"。由于团队间协作关系的改善,整个组织的效率因此得到提升,伴随频繁变化而来的生产环境的风险也能得到降低。
3. DevOps对应用程序发布的影响
在很多企业中,应用程序发布是一项涉及多个团队、压力很大、风险很高的活动。然而在具备DevOps能力的组织中,应用程序发布的风险很低,原因如下 [1]:
(1)减少变更范围
与传统的瀑布式开发模型相比,采用敏捷或迭代式开发意味着更频繁的发布、每次发布包含的变化更少。由于部署经常进行,因此每次部署不会对生产系统造成巨大影响,应用程序会以平滑的速率逐渐生长。
(2)加强发布协调
靠强有力的发布协调人来弥合开发与运营之间的技能鸿沟和沟通鸿沟;采用电子数据表、电话会议、即时消息、企业门户(wiki、sharepoint)等协作工具来确保所有相关人员理解变更的内容并全力合作。
(3)自动化
强大的部署自动化手段确保部署任务的可重复性、减少部署出错的可能性。
更多内容请看下回。