下载

5下载券

加入VIP
  • 专属下载特权
  • 现金文档折扣购买
  • VIP免费专区
  • 千万文档免费下载

上传资料

关闭

关闭

关闭

封号提示

内容

首页 云计算

云计算.pdf

云计算

jingxin886
2009-11-28 0人阅读 举报 0 0 暂无简介

简介:本文档为《云计算pdf》,可适用于IT/计算机领域

摘要云计算可望提高应用程序部署速度、促进创新和降低成本同时还增强经营敏捷性。Sun抱持一种全面的云计算观点因而可以支持各个层面其中包括服务器、存储、网络和虚拟化技术这些技术将云计算环境扩展到虚拟设备中运行的软件而这些虚拟设备可用来在极少时间内成功汇编应用程序。本白皮书探讨云计算如何变革我们的设计、构建和提供应用程序的方式以及企业在采纳并应用云计算技术时必须考虑的架构问题。云计算架构介绍白皮书第版年月本页故意留空。Sun公司目录引言Sun公司观点云计算的性质扩大已形成的趋势将虚拟机作为标准部署对象按需、自助、以使用情况付费的模式通过网络提供服务开放源软件的作用云计算基础设施模式公用云、专用云和混合云云计算的架构层云应用程序设计接口云计算效益缩短运行时间和响应时间最大限度地减轻基础设施风险降低入市成本加快创新步伐实现IaaS必须考虑的架构问题不断发展的应用程序架构变革架构的途径变革应用程序设计目标仍然相同一致而稳定的抽象层标准有助于解决复杂问题松散耦合、无状态、原地失败(FailinPlace)计算水平扩展并行化分割并征服数据物理数据与处理之间的关系编程策略合规与数据物理安全性与数据物理网络安全做法Sun公司与云计算来自Sun社区的创新社区与开放式标准选择的重要性选择云计算提供商感谢Sun公司云计算架构介绍第章引言什么是云计算(CloudComputing)每个人都有自己的看法。云计算可以是租用一台服务器或一千台服务器并在目前世界上最强大的系统上运行地球物理建模应用程序的能力。云计算也可以是租用一个虚拟服务器、在其上面加载软件、随意打开和关闭该虚拟服务器或克隆该服务器十次以满足突发工作负荷需求的能力。云计算可以存储并保护巨量数据而且这些数据只允许授权应用程序和用户进行访问。云计算可由建立一个包括OS、Apache、MySQL™数据库、Perl、Python和PHP的平台的云提供商提供支持该平台能够根据不断变化的工作负荷自动扩展。云计算还可以是在互联网上使用存储并保护数据同时提供服务包括电子邮件、销售能力自动化(SalesForceAutomation)和报税(TaxPreparation)等等的应用程序的能力。云计算可以使用存储云(StorageCloud)来保存应用程序、企业和个人数据。而且云计算还可以使用少数Web服务来集成照片、地图和GPS信息以便与客户Web浏览器中创建聚合(Mashup)。Sun公司观点Sun公司采取一种全面的观点这种观点认为云的类型有很多种而且有很多不同的应用程序可以使用云来构建。由于云计算有助于提高应用程序部署速度有助于加快创新步伐因而云计算可能还会出现我们现在无法想像到的形式。然而永恒不变的是Sun公司是一家具有丰富经验的服务器、网络和软件技术提供商我们提供的这些技术均支持云计算。作为创造“网络就是计算机”(TheNetworkistheComputer™)这一短语的公司我们深信云计算就是下一代的网络计算。云计算与以前的模式有什么区别就云计算这个短语而言它就是通过网络把信息技术当作服务来使用。我们将其定义为封装的、具有API且通过网络提供的服务。此定义同时包含把计算和存储资源当作服务使用。云计算首先以效率原理为基础此处所说的效率是指产生用来处理的使用案例的高级工具这样才能以一种惊人的速度创建和部署应用程序。云计算可以由企业数据中心自己的服务器进行提供也可以由承担拥有基础设施的全部风险的云提供商提供。错误的观念认为资源是取之不尽的。尽管该领域还处于萌芽阶段但其模式已在信息技术(IT)行业引起极大反响。现在云计算的主要模式称为“把基础设施当作服务”(IaaS)而且由于其突出特性IaaS模式成为本白皮书第一版本的焦点。本白皮书探讨云计算的性质及其如何在变革世界各地的企业构建和部署应用程序的方式的同时扩大已形成的趋势。然后讨论云架构设计师(CloudArchitect)设计基于云的应用程序时必须考虑的架构问题。最后介绍Sun公司提供的支持云计算的技术。Sun公司云计算架构介绍第章云计算的性质扩大已形成的趋势云计算推动降低服务提供成本的已有趋势同时提高部署服务的速度和敏捷性。它缩短了从设计应用程序架构到实际部署应用程序的时间。云计算把虚拟化、按需部署、网上服务提供和开放源软件融合在一起。从一种观点看云计算并非新生事物因为它使用既有的方法、概念和最佳做法。而从另一种观点看一切都是新的因为云计算变革我们发明、开发、部署、扩展、更新、维护和支付应用程序以及运行应程序的基础设施的方式。在本章中我们考查上述趋势以及这些趋势是如何成为云计算的性质的核心的。将虚拟机作为标准部署对象在过去几年时间里虚拟机已成为一种标准部署对象。虚拟化进一步增强了灵活性因为它把硬件概括到这样一个高度:在硬件上面可以在不需要连接具体物理服务器的情况下部署和重新部署软件栈。虚拟化实现了一个动态数据中心其中的服务器提供一个包含可根据需要使用资源的资源池而且其中的应用程序与计算、存储和网络资源的关系可动态变化以适应工作负荷和业务需求。由于应用程序部署与服务器部署相分离因而可以快速部署和扩展应用程序而不必首先购置物理服务器。虚拟机已成为流行抽象概念和部署单位因为它们是服务提供商和开发人员之间的最小公分母连接体。把虚拟机用作部署对象足以适应的使用情况而且这将有助于满足快速部署和扩展应用程序的需要。虚拟设备(包含软件的虚拟机这些软件部分或全部地配置为执行像Web服务器或数据库服务器这样的特定任务)进一步增强了快速创建和部署应用程序的能力。把虚拟机和设备作为标准部署对象组合在一起是云计算的关键特性之一。计算云通常由存储云进行补充存储云通过API提供虚拟化存储而这些API为存储虚拟机映像(Image)、用于诸如Web服务器的组件的源文件、应用程序状态数据以及一般业务数据提供便利。按需、自助、以使用情况付费的模式云计算的按需、自助和以使用情况付费的性质也是已有趋势的一种延伸。从企业的观点看云计算的按需性质有助于支持服务水平目标的性能和容量方面。云计算的自助性质使机构可以创造根据工作负荷和目标性能参数进行扩展和收缩的弹性环境。而且云计算的按使用情况付费的性质可以采取设备租赁的形式设备租赁保证了云提供商提供一种最低的服务水平。Sun公司云计算架构介绍虚拟化是此模式的一个关键特性。早在几年前IT机构就已经明白虚拟化使他们可以方便快捷地创建已有环境的副本有时涉及多个虚拟机来支持测试、开发和分级(Staging)活动。这些环境的成本极小因为它们几乎不使用什么资源因而可以与生产环境共处于同样的服务器之上。同样地可以在已有服务器上的新虚拟机中开发和部署新应用程序在互联网上开放使用并且在应用程序在市场上取得成功时进行扩展。这种轻便的部署模式已经产生一种“进化式”(Darwinistic)业务开发方法其中软件的Beta版是对公众开放的而且由市场决定哪些应用程序值得进一步扩展和开发或者静静地报废。云计算通过自动化扩大了这一趋势。不是与IT机构洽谈购买用来部署应用程序的资源计算云是一个自助式命题其中一张信用卡即可购买计算周期而且可以使用Web接口或API创建虚拟机并在虚拟机之间建立网络关系。云不需要与IT机构或服务提供商签订长期服务合同而是按照根据使用情况付费或按Sip付费(PaybytheSip)的模式运作在这种模式下一个应用程序可能为运行一项作业几分钟或几小时而存在也可能为长期向客户提供服务而存在。构建计算云时就好像应用程序是临时的而计费是按照资源消耗情况进行的:使用的CPU小时数、移动的数据量或存储的数据的千兆字节(GB)数。使用和仅对使用的资源付费的能力把购买多少基础设施的风险从开发应用程序的机构转移给云提供商。这种能力还把架构决策的责任从应用程序架构设计师转移给开发人员。这种转移会增大风险即出于某种原因制定了流程的企业必须控制的风险以及系统、网络和存储架构设计师需要把云计算设计包括在内的风险。基础设施是可以编程的这种架构责任的转移产生重要的后果。过去架构设计师确定一个应用程序的各种组件如何在一组服务器上进行布局即如何连接、固定、管理和扩展这些组件。现在开发人员可以使用云提供商的API不仅在虚拟机上创建应用程序的初始结构而且还确定该应用程序如何扩展和演进以适应工作负荷的变化。看看下面这个类比:历史上使用Java编程语言编写软件的开发人员确定何时适合创建使多项活动同时推进的新线程。现在开发人员可以同样轻而易举地发现和连接一项服务使它们可以将一个应用程序扩展到这样一个高度:该应用程序可使用成千上万个虚拟机来适应需求激增情况。动态编写应用程序架构的程序的能力使开发人员拥有了巨大权力同时也承担相应大的责任。要最有效地使用云计算开发人员还必须是架构设计师而且该架构设计师需要能够创建自我监控和自我扩展的应用程序。该开发人员架构设计师需要清楚何时适合创建一个新的线程(而不是何时创建一个新的虚拟机)并创建如何把它们相互连接起来的架构模式。Sun公司云计算架构介绍一旦很好地理解并利用这种能力结果将会是蔚为壮观的。一个已经具有传奇色彩的故事是Animoto的聚合工具该工具从一组映像和音乐中创建一个视频。该公司的应用程序在仅仅三天时间里从台服务器扩展到台服务器这部分是因为一个使该应用程序能够容易地扩展的架构。为了达到这一目的该应用程序必须设计为可以水平扩展、具有有限的状态并且通过云API管理自己的部署。对于每个像这样的成功案例都可能会成为一个相似的故事:其中该应用程序不能自我扩展而且无法满足消费者的需求。这种从开发人员到开发人员架构设计师的转移的重要性是无法理解的。看看您的企业数据中心是否能够以这么快的速度将一个应用程序扩展为适应如此快速增加的工作负荷以及云计算是否可以测量您的当前能力。应用程序是组合在一起的而且设计为可以组合的这种自助式、按使用情况付费的模式的另一个后果是就像编写应用程序一样通过汇编和配置设备和开放源软件来组合应用程序。可以重构(Refactor)以最大限度地利用标准组件的应用程序和架构是那些将会在利用云计算效益方面最为成功的应用程序和架构。同样地应用程序组件应设计为可以组合的这种组合是通过将应用程序构建的易于使用来实现。这要求具备简单而明确的功能以及精心编写文档的API。构建大型完整应用程序已成为过去因为可直接使用或根据特定用途定制的现有工具库已经变得越来越大。例如像Hadoop(一种开放源MapReduce架构实现)这样的工具可以在多种情况下使用其中可以对一个问题及其数据进行重构以便于其多个部分可以同时执行。当《纽约时报》想将其档案中万份文章和映像转换成为PDF格式时其内部IT机构说这会需要七个星期时间。同时使用个运行Hadoop的AmazonEC简单Web服务接口实例的一名开发人员用小时时间就完成了这项工作劳动成本只有美元。(这不包括上载数据所需的时间或存储成本。)甚至大型企业都可以使用云计算用来以比传统企业计算更少的时间和成本解决重大问题。Web应用程序部署示例举一个虚拟化与自助服务结合在一起如何促进应用程序部署的示例看看如何在云中进行一次二层Web应用程序部署(图):开发人员可以从一个预配置虚拟机映像库中选择负载平衡器(LoadBalancer)、Web服务器和数据库服务器设备。开发人员配置每个组件以制作一个自定义映像。配置负载平衡器通过将静态内容上载到存储云来给Web服务器填充这些内容并用站点的动态内容来填充数据库服务器设备。开发人员把自定义代码层叠在新的架构之中从而使组件满足特定应用程序要求。有关如何完成这一壮举的说明请访问:http:openblogsnytimescomselfserviceproratedsupercomputingfunselfserviceproratedsupercomputingfunSun公司云计算架构介绍开发人员选择一个呈现各层映像并部署这些映像的模式以便于处理网络、安全和可扩展性问题。图以基于云的部署形式将应用程序部署到一个二层Web服务器架构模式的示例。安全而高度可用的Web应用程序启动并正常运行。当需要更新应用程序时可以在开发测试生产链之间对虚拟机映像进行更新、版本控制和复制并且可以重新部署整个基础设施。云计算假定一切都是临时的而且重新部署整个应用程序就像手动修补一组具体的虚拟机一样容易。在此示例中虚拟机映像的抽象性质支持一种组合式应用程序开发方法。通过重构该问题可以使用一组标准的组件来快速部署应用程序。借助此模式可以迅速满足企业的业务需要而不需要对服务器、存储和网络基础设施进行耗时的人工购买、安装、布线和配置工作。通过网络提供服务不言而喻云计算扩大了通过网络提供服务的已有趋势。几乎每个商业机构都认可与其应用程序的连接的基于Web的接口的价值不管是否通过互联网向客户提供应用程序也不管它们是否是可供授权员工、合作伙伴、供应商和咨询人员使用的内部应用程序。当然基于互联网的服务提供的美妙之处就在于可以随时随地使用应用程序。尽管企业都清醒地认识到利用安全套接字层(SSL)以及严格验证技术来确保通信安全的能力但在云计算环境中引入信任还需要认真考虑企业计算和云计算之间的区别。如果架构设计的合理互联网服务提供模式可提供各种规模的企业所需的灵活性和安全性。开放源软件的作用开放源软件在云计算中发挥着一种重要的作用因为开放源软件允许从容易访问的组件创建其基本软件元素:虚拟机映像和设备。这会产生巨大的影响:Sun公司云计算架构介绍•例如开发人员可以通过将MySQL软件层叠在一个OpenSolaris™操作系统上并执行自定义来创建一个数据库设备(图)。像这样的设备能够根据需要创建、部署和动态扩展云计算应用程序。例如看看开放源软件如何使Animoto创建的应用程序在几天之内就扩展到个实例。᭄᥂ᑧ᪡԰㋏㒳ᑨ⫼⿟ᑣ៪Ё䯈ӊ䆒໛㰮ᢳᴎ᯴ڣ可以通过把开放源软件层叠在一个虚拟机映像之中并执行简化其部署的自定图义来创建设备。在此示例中通过把MySQL软件层叠在OpenSolaris操作系统上来创建一个数据库设备。•由于用开放源组件汇编大型应用程序非常容易因而生成更多开放源组件。这反过来又使开放源软件的作用更加重要。例如需要拥有一种可在云计算环境中运行的MapReduce算法这就是刺激开发该算法的因素之一。既然创建了工具就可以用它来进一步提高开发人员编写云计算应用程序的水平。云计算基础设施模式当从一个标准企业应用程序部署模式向一个基于云计算的应用程序部署模式转变时云计算架构设计师需要考虑许多问题。有的公用云和专用云提供互补的优点有三种基本服务模式需要考虑并且需要对比开放API和专有API的价值。公用云、专用云和混合云IT机构可以选择在各有其取舍的公用云、专用云或混合上部署其应用程序。公用、专用与混合这几个术语并不规定位置。公用云一般就在互联网上而专用云通常在建筑物内还有可能设在主机托管场所。企业可以就选用哪种云计算模式考虑多种因素而且有可能选用不只一种模式来解决多种不同问题。如果是临时需要的应用程序可能最适合在公用云上部署因为这样可以避免为了临时的需要而购买额外设备的情况。同样地永久使用或对服务质量或数据位置有具体要求的应用程序最好在专用云或混合云上部署。Sun公司云计算架构介绍公用云公用云由第三方运行而不同客户提供的应用程序可能会在云的服务器、存储系统和网络上混合在一起(图)。公用云通常在远离客户建筑物的地方托管而且它们通过提供一种像企业基础设施进行的灵活甚至临时的扩展提供一种降低客户风险和成本的方法。如果在实施一个专用云时牢记性能、安全性和数据保存位置那么该云中运行的其它应用程序的存在应对云架构设计师和最终用户都是透明的。的确公用云的优点之一是它们可以比一个公司的专用云大很多因而能够根据需要进行伸缩并将基础设施风险从企业转移到云提供商哪怕仅仅是临时性的。可以将公用云的部分划出去以便于独占单个客户端从而产生一个虚拟专用数据中心。虚拟专用数据中心不是仅限于在公用云中部署虚拟机映像而是使客户在更大程度上清楚地了解其基础设施。现在客户不仅可以处理虚拟机映像而且可以处理服务器、存储系统、网络设备和网络拓扑。利用位于同一场所的所有组件创建一个虚拟专用数据中心有助于缓解数据位置问题因为当在同一场所内连接资源时带宽非常充足而且一般都可用。公用云向多个客户提供服务而且一般在主机托管场所进行部署。图专用云专用云是为一个客户单独使用而构建的因而提供对数据、安全性和服务质量的最有效控制(图)。该公司拥有基础设施并可以控制在此基础设施上部署应用程序的方式。专用云可部署在企业数据中心中也可以将它们部署在一个主机托管场所。Sun公司云计算架构介绍专用云可由公司自己的IT机构也可由云提供商进行构建。在此“托管式专用”模式中像Sun这样的一个公司可以安装、配置和运营基础设施以支持一个公司企业数据中心内的专用云。此模式赋予公司对于云资源使用情况的极高水平的控制能力同时带来建立并运作该环境所需的专门知识。专用云可以托管在某个主机托管场所也可以托管在企业数据中心之中。它们可以图由公司支持也可以由云提供商提供支持还可以由像外包公司这样的第三方提供支持。混合云混合云把公用云模式与专用云模式结合在一起(图)。混合云有助于提供按需的、外部供应的扩展。用公用云的资源扩充专用云的能力可用来在发生工作负荷快速波动时维持服务水平。在利用存储云支持Web应用程序时这最常见。混合云也可用来处理预期的工作负荷高峰。专用云有时称为“超负荷计算”(SurgeComputing)可用来执行易于在公用云上部署的定期任务。混合云引出确定如何在公用云与专用云之间分配应用程序的复杂性。需要考虑的问题包括数据和处理资源之间的关系。如果数据量小或应用程序无状态与必须把大量数据传输到一个公用云中进行小量处理相比混合云要成功得多。Sun公司云计算架构介绍混合云把公用云模式和专用云模式结合起来而且当这两种类型的云位于同一图场所时混合云特别有效。云计算的架构层Sun公司的云计算观点是一种全面的观点:云计算可描述在从硬件到应用程序的任何传统层级提供的服务(图)。实际上云服务提供商倾向于提供可分为如下三个类别的服务:把软件当作服务(SoftwareasaService)、把平台当作服务(PlatformasaService)以及把基础设施当作服务(InfrastructureasaService)。这些类别把如图所示的各种层级组合在一起其中存在某种重叠。把软件当作服务(SaaS)“把软件当作服务”的特色是根据需要作为服务提供的一整套应用程序。该软件的单个实例运行于云上并为多个最终用户或客户机构提供服务。最著名的SasS示例是salesforcecom不过许多其它实例已经进入市场其中包括提供基本商业服务(包括电子邮件和文字处理)的GoogleApps。尽管salesforcecom诞生比云计算定义的出现早了几年但它现在通过利用其伴侣forcecom运作后者可定义为“把平台当作服务”。Sun公司云计算架构介绍෎ѢWebⱘᑨ⫼⿟ᑣǃGoogleᑨ⫼⿟ᑣǃsalesforcecomǃ᡹⿢ǃFlickrWeb᳡ࡵǃFlickrAPIǃGoogleഄ೒APIǃᄬټ㰮ᢳЏᴎᠬㅵDŽՓ⫼乘䜡㕂ⱘ䆒໛៪㞾ᅮН䕃ӊᷜǃAMPǃGlassFishㄝDŽ⾳⫼乘䜡㕂ⱘ᪡԰㋏㒳DŽ⏏ࡴ㞾Ꮕⱘᑨ⫼⿟ᑣDŽ՟བ˖DNS᳡ࡵ఼⾳⫼㰮ᢳ᳡ࡵ఼DŽ䚼㕆ϔϾVM᯴ڣ៪ᅝ㺙㞾Ꮕⱘ䕃ӊᷜ⾳⫼䅵ㅫ㔥ḐDŽ՟བ˖HPCᑨ⫼⿟ᑣᑨ⫼⿟ᑣ᳡ࡵЁ䯈ӊ᪡԰㋏㒳㰮ᢳ᳡ࡵ఼⠽⧚᳡ࡵ఼ѥ෎⸔䆒ᮑ⹀ӊ੠䕃ӊᷜ云计算意味着把图IT基础设施用作一项服务而且该服务可以是从租用原始硬件到使用第三方API的任何事情。把平台当作服务(PaaS)“把平台当作服务”包含一个软件层并作为一项服务提供此软件层这项服务可用来构建更高水平的服务。从服务生产商或消费者的观点看关于PaaS的观点至少有两种:•生产PaaS的某个人可能通过集成OS、中间件、应用软件甚至是一个随后作为服务提供给客户的开发环境来生产一个平台。例如开发PaaS的人可能会使其以一组Sun™xVM管理程序虚拟机为基础这组虚拟机包括一个NetBeans™集成化开发环境、一个SunGlassFish™Web栈并支持像Perl或Ruby这样的其它编程语言。•使用PaaS的人会看到一个封装式服务该服务是通过API提供给用户的。客户通过API与该平台互动而且该平台执行一切必要的操作来管理和扩展其本身以提供规定的服务水平。虚拟设备可以归类为PaaS的实例。例如一个内容交换设备会将其所有组成软件对客户隐藏起来而只向客户提供用来配置和部署服务的一个API或GUI。PaaS产品可执行各个阶段的软件开发和测试也可以专用于某个领域例如内容管理。PaaS的商业示例包括GoogleAppEngine它在Google的基础设施上提供应用程序服务。像这样的PaaS服务可提供一个用来部署应用程序的强大基础然而它们可能会由于云提供商选择提供的能力而受到制约。Sun公司云计算架构介绍把基础设施当作服务(IaaS)“把基础设施当作服务”通过网络作为标准化服务提供基本存储和计算能力。服务器、存储系统、交换机、路由器和其它系统都是合用的并可用来处理从应用程序组件到高性能计算应用程序的工作负荷。IaaS的商业示例包括Joyent其主要产品是提供高度可用的按需基础设施的一系列虚拟化服务器。云应用程序设计接口区分云计算与标准企业计算的关键特征之一是:基础设施本身是可以编成程序的。开发人员不是实际部署服务器、存储器和网络资源来支持应用程序而是指定如何配置和互连同样的虚拟组件包括如何从存储云存储和检索虚拟机映像和应用程序数据。开发人员指定如何且何时通过云提供商指定的API来部署组件。这与文件传输协议(FTP)的工作方式相似:FTP服务器维持与会话期间一直开放的客户端的控制连接。当要传输文件时该控制连接用来向服务器提供一个来源或目标文件名并协商一个用于文件传输本身的源和目标端口。从某种意义上讲云计算API就像FTP控制信道一样:云计算API在使用云期间是开放的而且控制如何利用云来提供开发人员向往的最终服务。控制如何利用云基础设施的API的使用具有一个缺陷:与FTP协议不同的是云API尚未标准化因此每个云提供商都有自己用来管理其服务的特定API。这是一个新兴行业的典型状态其中每个供应商都有其专有技术这样的技术往往把客户限制在其服务里因为专有API使得变更提供商非常困难。请查找在尽可能多的地方使用标准API的提供商。标准API现在可用来访问存储设备而随着时间的推移用来部署和扩展应用程序的API可能会被标准化。另外请查找有哪些云提供商了解其市场而且提供存档并部署虚拟机映像和预配置设备的方法。云计算效益要想从云计算中实现最大效益开发人员必须能够重构其应用程序使应用程序可以最有效地利用云计算所支持的架构和部署方式。使用云计算部署应用程序的优点包括缩短运行时间和响应时间、最大限度地减轻部署物理基础设施的风险、降低入市成本以及加快创新步伐。缩短运行时间和响应时间对于弹性地使用云来运行批量作业的应用程序来说云计算使得使用台服务器在相当于单个服务器所需的千分之一的时间里完成一项任务变得非常简单。前面引用的《纽约时报》的示例就是一个很好的批作业示例通过利用云极大地缩短了其运行时间。Sun公司云计算架构介绍对于需要向其客户提供良好响应时间的应用程序来说重构应用程序以便把任何CPU密集型任务外包给“工人”(Worker)虚拟机有助于优化响应时间同时还能根据需求进行伸缩从而满足客户需求。前面引用的Animoto应用程序就是云如何用来扩展应用程序并维持服务质量水平的一个很好的示例。最大限度地减轻基础设施风险IT机构可以利用云来减轻购置物理服务器所固有的风险。新的应用程序是否将会成功如果成功需要多少台服务器部署这些服务器的步骤是否能够跟得上工作负荷增加速度如果不能投入服务器中的大量资金会不会付之东流如果该应用程序的成功非常短命IT机构是否还会在多数时间里处于空闲状态的大量基础设施中进行投资当把一个应用程序推出到云中时可扩展性和购买太多或太少基础设施就成为云提供商的问题。越来越多的案例表明云提供商的基础设施规模如此之大以至于可以容忍各个客户的业务量增长和工作负荷尖峰情况因而减轻了这些客户所面临的经济风险。云计算最大限度地减轻基础设施风险的另一条途径是实现超负荷计算其中企业数据中心(也许是实现专用云的数据中心)通过一个允许其向一个公用云发送超溢工作来扩大其处理工作负荷尖峰情况的能力。在一个资源不再稀缺而且能够以较低成本更好地满足资源需求的环境中可以更好地处理应用程序生命周期管理问题。降低入市成本云计算的许多属性有助于降低进入新市场的成本。•由于基础设施是租用的而不是购买的成本得到控制而且资本投资可能为零。除通过按Sip购买计算周期和存储空间来降低购置成本之外云提供商的巨大规模也有助于最大限度地降低成本从而有助于进一步降低入市成本。•应用程序与其说是通过汇编倒不如说是通过编程来开发的。这种快速应用程序开发方法非常规范有助于缩短入市时间因而有可能使在云环境中部署应用程序的机构先于竞争者入市。加快创新步伐云计算有助于加快创新步伐。降低进入新兴市场的成本有助于使竞争各方处于同一起跑线因而使新创企业可以快速而低成本地部署新的产品。这使小公司可以更有效地与在企业数据中心领域里所经历的部署过程长得多的传统机构进行竞争。增强竞争能力有助于加快创新步伐而且由于许多创新是通过利用开放源软件实现的整个行业都会从云计算技术所促成的创新步伐加快而受益。Sun公司云计算架构介绍第章实现IaaS必须考虑的架构问题不断发展的应用程序架构正如我们已经说明的:云计算是当前趋势和最佳做法的自然延伸从架构观点看云计算也是如此。再次强调云计算并非新生事物不过在其实现中云计算改变我们所做的一切工作。变革架构的途径在世纪年代人们谈论的话题是关于如何把一个应用程序分解成各种组件然后是如何将这些组件部署到不同的服务器上以便优化非功能要求包括可扩展性、可用性、易管理性和安全性。现在我们所维持的是一个分解式应用程序架构同时实际部署到一个利用虚拟化的整合式架构上。云计算通过提供一种有计划地部署应用程序架构的方法来继续这一趋势最终实现一个动态数据中心的承诺。在云计算中效率受到高度重视如果无法快速而有计划地部署应用程序架构那么该应用程序就可能不是一个适合于此种模式的应用程序。变革应用程序设计过去应用程序设计为通过垂直扩展来处理大型工作负载。将更多处理器和内存安装在一个邮件服务器上来处理更大的流量。扩展数据中心服务器以提高吞吐量。在超级计算机上运行高性能计算作业。从高度可扩展的对称型多处理器迁移到价格低廉但可扩展性差的x架构服务器已经对应用程序设计产生了影响。开发人员并不期望应用程序运行于高度可扩展的服务器而是重构其应用程序以便能够在多个服务器之间进行水平扩展。此应用程序重构并不总是容易进行的因为应用程序及其数据都必须进行设计这样才能把处理和数据同时分解成为较小的数据块。这一已有架构趋势已经成为推广云计算的一个关键因素。这一趋势的示例包括:高性能计算高性能计算(HPC)工作负荷已经在光金属(BareMetal)计算网格上运行有一段时间了这是通过应用程序重构实现的。例如科学家已经找到为像D气候建模这样的应用程序削减数据的方法因而可以在许多服务器上展开应用程序。网格计算(GridComputing)是云计算的“前辈”这是因为网格计算使用工具来供应和管理多架物理服务器这样这些服务器就可以共同配合来解决一个问题。由于具有极高的计算、互处理通信和IO需求HPC工作负荷非常适合于作为服务提供基础设施的云尤其是提供对IO设备进行更直接访问的光金属服务器或TypeI虚拟机。Sun公司云计算架构介绍数据库管理系统数据库管理系统通过水平扩展数据库服务器并在其之间对表进行分区已经适应于在云环境中运行。此技术称为“分片”(Sharding)使多个数据库软件实例(通常是MySQL软件)可以在云环境中扩展性能。应用程序现在不是访问单个中央数据库而是访问多个数据库实例中的一个具体取决于哪个“碎片”(Shard)包含所需数据(图)。ᑨ⫼⿟ᑣ᭄᥂ᑧ᭄᥂ᑧ᭄᥂ᑧ㒣䖛ߚऎⱘᑨ⫼⿟ᑣ᭄᥂ߚᏗ೼∈ᑇᠽሩ᭄᥂ᑧᅲ՟П䯈ⱘᑨ⫼⿟ᑣ᭄᥂数据库分片技术在多个数据库管理系统实例之间对数据库表进行分区可通过水图平扩展来支持大型数据库。CPU密集型处理执行像帧渲染(FrameRendering)这样的活动的应用程序已经设计为不是为每个帧创建一个新线程而是创建一个单独的虚拟机来渲染每个帧因而通过水平扩展来提高性能。数据密集型处理开放源社区正在开发一般化工具这些工具可帮助处理大量数据然后将结果聚集到相应的进程中。例如Hadoop就是MapReduce问题的一种开放源实现这种实现将“工人”(Worker)虚拟机与他们所需的数据的部署集合在一起。目标仍然相同应用程序架构方面的许多进步都有助于促进云计算的推广。这些进步有助于支持高效地部署应用程序的目标同时有助于使应用程序具有弹性并适度地自动扩展。然而杰出应用程序架构的首要目标始终没有发生任何变化:那就是支持同样的始终至关重要的特征:•可扩展性。此特征的重要性始终未曾改变。为云计算设计的应用程序需要根据工作负荷需求进行伸缩这样性能及与服务水平的符合性就保持适当。为了达到这一点必须将应用程序及其数据松散耦合以使可扩展性最大Sun公司云计算架构介绍化。“弹性”这一术语经常适用于伸缩云应用程序因为云计算应用程序必须不仅可以扩展而且必须在工作负荷减小时能够缩小以免抬高在云中的部署成本。•可用性。无论应用程序是向社交网站用户提供服务还是管理大型制造企业的供应链互联网应用程序用户都期望这些应用程序每时每刻都能正常运行。Sun公司在此领域的行业领先地位早在其推出SunToneSM认证计划时就已确立该计划有助于客户证明其应用程序和服务达到要求的可用性水平。•可靠性。随着时间的推移对于可靠性的重视程度已经发生转变。如果大型应用程序是指大型对称多处理系统那么可靠性就意味着系统组件极少发生故障而且即使发生故障也可以在不中断系统正常运行的情况下进行更换。现在架构适应此特征的方式是把应用程序设计为:即使分解运行应用程序的一个或多个服务器或虚拟机应用程序仍能继续运行而且其数据不会受到破坏。正是在这个方面我们曾经担心个别服务器组件发生故障而现在我们构建即使全部服务器发生故障也不会造成破坏的应用程序。•安全性。设备需要只对获得授权且通过身份验证的用户提供访问权而且这些用户需要能够确信其数据是安全的。无论应用程序帮助各个互联网用户准备其纳税申报表还是应用程序在公司及其供应商之间交换保密信息都是如此。现今环境中的安全性是通过如下手段确立的:利用严格的身份验证、授权和帐号管理程序确保静止和移动中数据的安全性锁定网络以及硬化操作系统、中间件和应用软件。安全性是这样一个系统特性以至于我们不再单独强调安全性必须将安全性融合到应用程序的各个方面以及应用程序部署和操作架构和进程中。•灵活性和敏捷性。这些特征越来越重要因为商业机构发现他们必须通过提高向客户提供应用程序的速度来更快地适应不断变化的经营环境。云计算强调通过利用最适合的构件(BuildingBlock)来快速完成工作使应用程序非常快速地面市。•可维护性。一旦部署一个应用程序就需要对其进行维护。过去可维护性意味着使用的服务器可以在不停机或极少停机的情况下进行修理。现在可维护性是指更新甚至更换一个应用程序的基本基础设施组件时不会破坏该应用程序的特征其中包括可用性和安全性。•效率。这是特征列表上的新特征或许这是最能将云计算模式与其它计算模式区别开来的一个特征。效率是云计算的意义所在而且如果不能方便快捷地在云中部署应用程序即使可从模式中受益该计算模式也可能不是一个良好的可选模式。例如企业资源规划应用程序可能最适合于垂直扩展的系统并可能在近期通过SaaS提供。不过提取、处理和呈现这些系统中派生的数据的应用程序可能非常适合于在云中部署。Sun公司云计算架构介绍一致而稳定的抽象层云计算提高了抽象水平这样所有组件都抽象化或虚拟化并可用来迅速组合较高级别的应用程序或平台。如果某个组件不向其客户或同行提供一致而稳定的抽象层该组件就不适合于云计算。标准部署单位是虚拟机它本质上可运行于抽象硬件平台。人们很容易过度关注构建虚拟机映像而忽视用来创建虚拟机映像的模式。在云计算中维持该模式而非映像本身非常重要。该模式是保留下来的而映像则是从该模式产生的。虚拟机映像将始终在变化因为虚拟机映像内的软件层将总是需要修补、升级或重新配置。不变的是创建虚拟机映像的流程而且这是开发人员所应重视的。开发人员可以通过把Web服务器、应用程序服务器和MySQL数据库服务器层叠在一个操作系统映像上应用补丁程序、配置更改以及互连各层组件来构建虚拟机映像。重视模式而非虚拟机映像可以通过重新把模式应用到一组新组件根据需要来更新这些映像本身。凭借这一标准部署单位云架构设计师可以使用有助于以较低成本加快部署速度的设备。开发人员可以使用一个设备该设备预配置为通过与该设备的API进行互动在OpenSolarisOS上运行Hadoop。架构设计师可以使用内容交换机这些内容交换机不是作为物理设备部署的而是作为虚拟设备部署的。部署该设备所需要做的一切事情只是与其API或GUI进行互动。即使生产带有许可证的商用软件的公司都在通过更加灵活、基于使用情况的许可模式来适应云计算。无论是调用一个创建虚拟机映像的模式还是定制一个设备结果产生的虚拟机映像都需要存储在企业进行版本控制并提供支持的映像库中。标准有助于解决复杂问题云计算首先重视效率因而采用少数标准和标准配置有助于降低维护和部署成本。拥有可简化部署的标准比拥有用于作业的最佳环境更重要。规则就在这里发挥作用:云计算重视可以支持使用案例的少数标准。这就把经济情况从成本高的一次性实现转变为选择可最大限度地加以利用的构件。将来还会继续专业化但起点应从标准开始。对于要采用云计算的企业标准可以包括虚拟机类型、标准虚拟机映像中的操作系统、工具以及支持的编程语言。•虚拟机类型。想想虚拟机选择对于要支持的应用程序的影响。对于社交网站应用程序、出于安全性进行的隔离以及出于可移植性进行的高水平抽象会建议使用TypeII虚拟机。对于高性能计算或可视化应用程序需要直接访问硬件以实现最佳性能会建议使用TypeI虚拟机。Sun公司云计算架构介绍•预安装、预配置的系统。必须像在物理服务器上一样维护虚拟机上的软件。操作系统仍然需要硬化、修补和升级。拥有一小组标准化的受支持配置使开发人员可以使用当前支持的虚拟机。当升级支持的配置时应设计要求自定义的模式以便于容易地将更改重新应用到一个新的虚拟机映像。设备也是如此其中可以通过设备的标准API来配置当前版本。•工具和语言。企业可能以标准方式使用Java编程语言和RubyonRails小企业可以以标准方式将PHP作为其用于构建应用程序的首选工具。当这些标准在云计算上下文中成熟时它们开始形成下一层:把平台当作服务(PaaS)。虚拟化和封装技术支持重构当通过组合和配置一组虚拟机映像和设备重构并创建应用程序时要将重点放在特定虚拟机发挥什么作用上而不是放在如何实现该虚拟机上。虚拟化和封装技术将实现细节隐藏起来并使开发人员重新重视组件之间的接口和互动。这些组件应该提供标准接口以便于开发人员方便快捷地构建应用程序同时利用与性能或成本所要求的相似的功能来使用替代组件。应用程序开发是有计划地完成的甚至用来部署应用程序的程序也可以封装以便于利用和重新利用。可以封装部署三层式Web基础设施的程序这样该程序的参数就会包括指向用于Web服务器、业务逻辑和数据库层的虚拟机映像的指针。然后就可以执行此设计模式以便于部署标准应用程序而不必重新设想或甚至重新考虑(例如)支持每层所要求的网络架构。应用程序维护的云计算原则并非修补而是重新部署。管理创建虚拟机映像的模式而不是映像本身简化了这种重新部署。部署之后发现的问题解决起来相当容易或者通过更新组件虚拟机并调用用于重新部署的设计模式来发布应用程序的新版本。当开发人员修补虚拟机时只需要创建一个虚拟机映像而且要有计划地复制并部署其余映像。应对虚拟机进行版本控制以便于必要时回滚。䚼㕆῵ᓣWEB᳡ࡵ఼᭄᥂ᑧ᳡ࡵ఼ᑨ⫼⿟ᑣ᳡ࡵ఼一种部署模式可以封装起来以便于重复利用。在此示例中一个模式指定图Web服务器、应用程序服务器和数据库服务器层而用此模式部署其本身的一个实例所需要的一切只是指向上述三层中各层的虚拟机的指针。Sun公司云计算架构介绍松散耦合、无状态、原地失败(FailinPlace)计算几年以来基于Web的应用程序已在向松散耦合和无状态转变。在云计算中这些特征甚至更加重要因为云计算具有更加动态的性质。应用程序映像不修补它们是用完丢弃的对象因而需要是无状态的。如果一个虚拟机失败应用程序必须继续不间断地运行。应用程序之间的耦合需要是松散的这样任何组件发生故障都不会影响整个应用程序的可用性。一个组件应该做到“原地故障”极少甚至不会对应用程序产生影响。由于应用程序组件越来越具有临时性因而不能包含存在时间超过任何应用程序实例的数据。应通过将状态推出软件来尽可能使应用程序无状态从而尽可能地将处理与数据分开。能够做到这一点的技术包括:•以Cookie的形式将状态推出到用户或者将状态代码编入URL。•将状态下推至后端数据库•维护数据的补充副本这是Hadoop使用的一个策略•使用基于网络的持久性技术例如GlassFish应用程序服

用户评价(0)

关闭

新课改视野下建构高中语文教学实验成果报告(32KB)

抱歉,积分不足下载失败,请稍后再试!

提示

试读已结束,如需要继续阅读或者下载,敬请购买!

文档小程序码

使用微信“扫一扫”扫码寻找文档

1

打开微信

2

扫描小程序码

3

发布寻找信息

4

等待寻找结果

我知道了
评分:

/32

云计算

VIP

在线
客服

免费
邮箱

爱问共享资料服务号

扫描关注领取更多福利