微软云计算Windows Azure(一)
一、微软云计算平台传统的企业和用户在开发和摆设自己的应用程序紧张有两种方式:
方法题目购买和维护自己底子设施耗费大量的资金和维护精力租用服务器或租用虚拟主机背景服务器的控制权低落,受到其他应用程序的影响 微软的云计算技术结合了上述两种方法的优点。用户也可以将他们的应用程序和数据摆设在微软云计算平台上。用户也可以在云中存储数据或依靠其他的云计算底子设施服务。
云计算平台依靠于微软强大的分布式集群,提供巨大的计算能力和存储能力,并具有很好的稳定性和可靠性。云计算平台接纳量入为出的方式,用户只需按照他们动态使用的计算和存储资源来付费。
微软的云计算服务平台Windows Azure属于PaaS模式,一般面向的是软件开发商。当前版本的Windows Azure平台包罗4个组成部门:
(1)Windows Azure:作为微软云计算操作系统,提供了一个在微软数据中心服务器上运行应用程序和存储数据的Windows环境。
(2)SQL Azure:它是云中的关系数据库,为云中基于SQL Server的关系型数据提供服务。
(3)Windows Azure AppFabric:为在云中或本地系统中的应用提供基于云的底子架构服务。
(4)Windows Azure Marketplace:为购买云计算环境下的数据和应用提供在线服务。
https://img-blog.csdnimg.cn/direct/228bc2088b234e039eec8217080f3af6.png#pic_center
Windows Azure平台体系架构 上述4个部门均运行在微软已运行的11个数据中心。11个数据中心分别摆设在北美(5个)、欧洲(2个)和亚洲(4个)。
二、微软云操作系统Windows Azure
(一)Windows Azure概述
微软云计算战略的核心——云计算操作系统。Windows Azure是一个服务平台,用户利用该平台,通过互联网访问微软数据中心运行Windows应用程序和存储应用程序数据,这些应用程序可以向用户提供服务。Windows Azure提供了托管的、可扩展的、按需应用的计算和存储资源,同时还提供了云平台管理和动态分配资源的控制本领。
https://img-blog.csdnimg.cn/direct/24a8afff4666404bbae812b2e819a7ba.png#pic_center
Windows Azure体系架构 (1)计算服务:为在Azure平台中运行的应用提供支持。
(2)存储服务:紧张用来存储二进制和布局化的数据。
(3)Fabric 控制器:紧张用来摆设、管理和监控应用。
(4)内容分发网络CDN:通过维持天下各地数据缓存副本,提高全球用户访问Windows Azure存储中的二进制数据的速率。
(5)Windows Azure Connect:在本地计算机和Windows Azure之间创建IP级连接,使本地应用和Azure平台相连。
(二)Windows Azure计算服务
https://img-blog.csdnimg.cn/direct/d83acd444ed64357ab526e0f26d8d332.png#pic_center
Windows Azure服务平台的CTP版提供了一整套的开发工具和组件允许创建.NET 4.0应用程序。与传统的.NET应用程序差异的是,Windows Azure应用程序包罗Web Role实例、Worker Role实例和VM Role实例,使用这三种实例的Windows Azure应用程序运行机制如图所示。
https://img-blog.csdnimg.cn/direct/2e5571683ea3470cbaef55eb6ec2927d.png#pic_center
(1)Web Role:基于Web Role可以使基于Web的应用创建过程变得简单
(2)Worker Role:Worker Role设计用来运行各种各样的基于Windows的代码
(3)VM Role:VM Role运行系统提供的Windows Server 2008 R2镜像。帮助将本地的Windows Server应用移到Windows Azure。
(三)Windows Azure存储服务
Windows Azure存储服务依靠微软数据中心,允许用户在云端存储应用程序数据。 应用程序可以存储任何数量的数据,而且可以存储任意长的时间,用户可以在任何时间、任何地方访问自己的数据。
(1)Table:提供更加布局化的数据存储。
(2)Blob:存储二进制数据,可以存储大型的无布局数据,容量巨大,可以或许满足海量数据存储需求。
(3)Queue:用来支持在Windows Azure应用程序组件之间举行通讯。
https://img-blog.csdnimg.cn/direct/21b1585c8acc4f9b83b0ca23a8a9cbd4.png#pic_center
1、全局定名空间
Windows Azure Storage(WAS)实现了一个单一的全局定名空间,使得用户从天下任何地方都可以一致地存储和访问云中数据,而且存储容量可以随着时间推移任意增长。存储名空间被划分为三部门:账户名(AccountName)、分区名(PartitionName)和对象名(ObjectName),全部的数据都通过如下的URI形式访问:
http(s)://AccountName.<service>core.windows.net/PartitionName/ObjectName
账户名:DNS主机名的一部门,是客户为访问存储而选择的账户名。
分区名:使用账户名定位存储集群后,在集群内将数据访问哀求进一步定位到存储节点。
对象名:用来对分区中的多个对象举行区分。对一些范例的数据,分区名可以唯一标识账户里的对象时,对象名就变得可要可不要了。
2、体系架构
https://img-blog.csdnimg.cn/direct/84fa5b47a7974b8084ef04a5ebb33a46.png#pic_center
3、存储域的层次布局
(1)文件流层:负责在多个服务器间分布和复制数据来保持存储域中数据的可用性。
(2)分区层:负责管理和理解上层数据抽象范例,提供一个可扩展的名空间。
(3)前端:由一组无状态服务器构成来处理访问哀求。
4、双复制引擎
为了实现数据高可用,WAS通过在文件流层举行域内数据复制和在分区层举行域间数据复制,实现必要的数据容灾掩护机制。
(1)域内复制:WAS在文件流层实现同步复制,包管存储域内的全部数据写在其内部是可靠的。
(2)域间复制:在对象级举行,对给定账户的整个对象或最近的差分更新举行复制。
域内复制专门为硬件失效而设计,在大规模系统内这类失效比力普遍,而域间复制提供跨地域冗余来防止地域劫难,这种环境一般不多出现。另一个原因是这两层所维护的名空间题目。
5、文件流层
https://img-blog.csdnimg.cn/direct/5ace7d0532b0485cab92f8cffc241a4e.png#pic_center
WAS追加写的操作流程如下:
步骤1:客户端将追加写哀求发送到主EN节点,主节点确定追加写在区块内的偏移量。
步骤2:当同一区块有多个并发追加写哀求时,对全部追加写哀求举行排序。
步骤3:发送追加写哀求到两个次EN节点,并附上选定的区块偏移量。
步骤4:当三个EN节点都成功追加写内容到磁盘后,反馈写成功消息给客户端。
在EN节点内数据的追加写操作步骤如下:
步骤1:将全部数据追加写到日记盘。
步骤2:对数据盘上的区块追加写哀求举行排队。
步骤3:如果日记操作先完成,则数据被缓存在内存中。
步骤4:一旦写成功就返回。
6、分区层
分区层存储差异范例的对象,并理解对于给定的对象范例(BLOB,表或队列)举行事务处理的意义。
分区层提供差异存储对象范例的数据模型,差异范例对象处理的逻辑和语义,大规模扩展的对象定名空间,跨多个可用分区服务器访问对象的负载平衡,访问对象的事务排序和强一致性。
https://img-blog.csdnimg.cn/direct/c554085f8e854f5395131ffbb0274823.png#pic_center
(1)分区管理器:负责生存对象表到分区段的划分和每个分区段到相应分区服务器的分配环境。
负责分区服务器之间的负载平衡。
(2)分区服务器:负责处来由分区管理器分配给它的一组分区段的哀求。
(3)锁服务:Paxos锁服务用于分区服务器的主服务器推举。别的,每个分区服务器为服务分区也保持锁服务租赁。
为了将负载分散到多个分区服务器和控制存储域内分区的总数,分区管理器可执行以下三种操作。
(1)负载平衡:当给定的分层管理器负载过高时,将一个或多个分区段重新分配到其他负载较低的分区服务器。
(2)划分:当单个分区段负载过高时,将其划分为两个或更多小的不重叠分区段,并重新分配它们到两个或更多分区服务器。
(3)合并:将负载低的分区段合并为对象表中一个一连键值段,并让存储域内的分区服务器数与分区段数保持在一定比例范围内。
WAS的分区服务器跟踪分区段内负载高的键值范围,并以此来确定分区段内的哪些键值必要被拆分。为了将一个分区段B拆分为两个新的分区段C和D,必要举行下列步骤。
步骤1:关照分区服务器将段B拆分为C和D
步骤2:处理B的检查点,再暂停相应的服务哀求
步骤3:使用一种“MultiModify”的特殊流操作处理B的每个流
步骤4:开始将服务哀求发送至新的分区C和D
步骤5:关照分区管理器拆分操作完成
分区管理器可以选择两个分区名范围不重叠的低负载分区段C和D,将它们合并为一个新的分区段E。
步骤1:将分区段C和D迁移到同一个分区服务器上,关照将C和D合并为E
步骤2:为C和D设置一个检查点,然后暂停相应的服务哀求
步骤3:使用MultiModify流下令创建一个新简直认日记和E的数据流
步骤4:构建区段E的元数据流
步骤5:开始发送合并后新分区段的服务哀求
步骤6:更新分区映射表和相应的元数据信息
(四)Windows Azure Connect
Connect在Windows Azure应用和本地运行的呆板之间创建一个基于IPsec协议的连接,使两者更轻易结合起来使用。
https://img-blog.csdnimg.cn/direct/a1916aba494a4802b0239e9b3a527aa2.png#pic_center
必要注意的是,Connect不是一个成熟的VPN(Virtual Private Network),只是一个简单的解决方案。
(1)Windows Azure应用可以或许直接访问本地的数据库。
(2)Windows Azure应用可以或许地域连接到本地环境。
(五)Windows Azure CDN
Windows Azure提供了一个内容分发网络CDN(Content Delivery Network)。这个CDN存储了距离用户较近的站点的Blobs副本。
https://img-blog.csdnimg.cn/direct/7f1c4ca07ee948a994c2252962c49743.png#pic_center
用户第一次访问Blob时,CDN存储了Blob的副本,存放的地点与用户在地理位置上比力靠近。当这个Blob被第二次访问时,它的内容将来自于缓存,而不是来自于离它位置较远的原始数据。
https://img-blog.csdnimg.cn/direct/36c37624dfc94ab1bfa0e5d536e7eb8b.png#pic_center
比方,Windows Azure提供一天体育变乱的视频,第一个用户访问视频时,用户不会从CDN中获益,由于Blob还没有缓存一个离用户较近点的位置,而同一地理位置的其他的用户将会从CDN中得到更好的性能,同时缓存副本可以使视频装载得更快。
(六)Fabric控制器
在数据中心中, Windows Azure的呆板聚集和运行在这些呆板上的软件均由Fabric控制器控制。
https://img-blog.csdnimg.cn/direct/6a6cc30a394043d1abad8da2418d2a5b.png#pic_center
Fabric控制器是一个分布式应用,拥有计算机、交换机、负载均衡器等各种资源。
[*]Fabric控制器控制全部运行的应用。
[*]Fabric控制器依靠配置信息决定运行的位置,选择物理服务器来最优化硬件使用。
[*]Fabric控制器使用配置文件决定必要创建的VMs(虚拟机)的数量。
[*]Fabric控制器在创建VMs后,还监控VMs。
Windows Azure提供给开发者5种规格的虚拟机,见表:
虚拟机规格配 置 情 况存 储 容 量Extra-small单核、1.0GHz CPU、768MB内存、I/O性能低200GB实例存储容量Small单核、1.6GHz CPU、1.75GB内存、I/O性能中等225GB实例存储容量Medium双核、1.6GHz CPU、3.5GB内存、I/O性能高490GB实例存储容量Large四核、1.6GHz CPU、7GB内存、I/O性能高1000GB实例存储容量Extra-large八核、1.6GHz CPU、14GB内存、I/O性能高2048GB实例存储容量
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]