《并行计算(陈国良版)课后答案(共14页).doc》由会员分享,可在线阅读,更多相关《并行计算(陈国良版)课后答案(共14页).doc(14页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上第三章 互连网络3.1 对于一颗K级二叉树(根为0级,叶为k-1级),共有N=2k-1个节点,当推广至m-元树时(即每个非叶节点有m个子节点)时,试写出总节点数N的表达式。 答: 推广至M元树时,k级M元树总结点数N的表达式为: N=1+m1+m2+.+m(k-1)=(1-mk)*1/(1-m);3.2二元胖树如图3.46所示,此时所有非根节点均有2个父节点。如果将图中的每个椭圆均视为单个节点,并且成对节点间的多条边视为一条边,则他实际上就是一个二叉树。试问:如果不管椭圆,只把小方块视为节点,则他从叶到根形成什么样的多级互联网络?答:8输入的完全混洗三级互联网络。3.
2、3 四元胖树如图3.47所示,试问:每个内节点有几个子节点和几个父节点?你知道那个机器使用了此种形式的胖树?答:每个内节点有4个子节点,2个父节点。CM-5使用了此类胖树结构。3.4 试构造一个N=64的立方环网络,并将其直径和节点度与N=64的超立方比较之,你的结论是什么? 答:A N=64的立方环网络,为4立方环(将4维超立方每个顶点以4面体替代得到),直径d=9,节点度n=4B N=64的超立方网络,为六维超立方(将一个立方体分为8个小立方,以每个小立方作为简单立方体的节点,互联成6维超立方),直径d=6,节点度n=63.5 一个N=2k个节点的 de Bruijin 网络如图3.48所
3、示,令。,是一个节点的二进制表示,则该节点可达如下两个节点:。0,。1。试问:该网络的直径和对剖宽度是多少?答:N=2k个节点的 de Bruijin网络 直径d=k 对剖宽带w=2(k-1)3.6 一个N=2n个节点的洗牌交换网络如图3.49所示。试问:此网络节点度=?网络直径=?网络对剖宽度=? 答:N=2n个节点的洗牌交换网络,网络节点度为=2 ,网络直径=n-1 ,网络对剖宽度=43.7 一个N=(k+1)2k个节点的蝶形网络如图3.50所示。试问:此网络节点度=?网络直径=?网络对剖宽度=?答:N=(k+1)2k个节点的蝶形网络,网络节点度=4 ,网络直径=2*k ,网络对剖宽度=2
4、k3.9 对于如下列举的网络技术,用体系结构描述,速率范围,电缆长度等填充下表中的各项。(提示:根据讨论的时间年限,每项可能是一个范围)答:网络技术网络结构带宽铜线距离光纤距离Myrinet专用机群互联网络200MB/秒25m500mHiPPI用于异构计算机和其外设的组网800Mbps1.6Gbps25m300m10kmSCI可扩展一致性接口,通常独立于拓扑结构250Mbps8Gbps光纤通信多处理器和其外围设备之间,直连结构100Mbps800Mbps50m10kmATM主要应用于因特网主干线中25Mbps10GbpsFDDI采用双向光纤令牌环,所有结点联接在该环中100-200Mbps10
5、0m2KM3.10 如图3.51所示,信包的片0,1,2,3要分别去向目的地A,B,C,D。此时片0占据信道CB,片1占据信道DC,片2占据信道AD,片3占据信道BA。试问: 1)这将会发生什么现象? 2)如果采用X-Y选路策略,可避免上述现象吗?为什么? 答: 1)通路中形成环,发生死锁 2)如果采用X-Y策略则不会发生死锁。因为采用X-Y策略时其实质是对资源(这里是通道)进行按序分配(永远是x方向优先于y方向,反方向路由是y方向优先于x方向),因此根据死锁避免的原则判断,此时不会发生死锁。3.12 在二维网孔中,试构造一个与X-Y选路等价的查表路由。答: 所构造路由表描述如下: 1)每个节
6、点包括两张路由表x表和y表 2)每个节点包含其以后节点信息,如节点【1,2】x表内容为:【2,2】【3,2】y表内容为:【1,3】 选路方法: 节点路由时进行查表:先查x表即进行x方向路由,如果查表能指明下一跳方向则直接进入下一跳。如果不能则继续查y表,直到到达目的地。第四章 对称多处理机系统4.1参照图4.20,试解释为什么采用WT策略进程从迁移到时,或采用WB策略将包含共享变量X的进程从迁移到时,会造成高速缓存的不一致。图4.20 进程迁移所造成的不一致性答:采用WT策略进程从迁移到后,写共享变量X为X,并且更新主存数据为X,此时共享变量值仍然为X,与和主存X不一致。采用WB策略进程从迁移
7、到后,写共享变量X为X,但此时缓存与主存变量值仍然为X,造车不一致。4.2参照图4.21所示,试解释为什么:在采用WT策略的高速缓存中,当I/O处理器将一个新的数据写回主存时会造成高速缓存和主存间的不一致;在采用WB策略的高速缓存中,当直接从主存输出数据时会造成不一致。图4.21 绕过高速缓存的I/O操作所造成的不一致性答:中I/O处理器将数据X写回主存,因为高速缓存采用WT策略,此时P1和P2相应的高速缓存值还是X,所以造成高速缓存与主存不一致。直接从主存输出数据X,因为高速缓存采用WB策略,可能高速缓存中的数据已经被修改过,所以造成不一致。4.3 试解释采用WB策略的写更新和写无效协议的一
8、致性维护过程。其中为更新前高速缓存中的拷贝,为修改后的高速缓存块,I为无效的高速缓存块。答:处理器P1写共享变量X为X,写更新协议如图(c)所示,同时更新其他核中存在高速缓存拷贝的值为X;写无效协议如图(b)所示,无效其他核中存在高速缓存拷贝,从而维护了一致性过程。4.4 两种基于总线的共享内存多处理机分别实现了Illinois MESI协议和Dragon协议,对于下面给定的每个内存存取序列,试比较在这两种多处理机上的执行代价,并就序列及一致性协议的特点来说明为什么有这样的性能差别。序列r1 w1 r1 w1 r2 w2 r2 w2 r3 w3 r3 w3;序列r1 r2 r3 w1 w2 w
9、3 r1 r2 r3 w3 w1;序列r1 r2 r3 r3 w1 w1 w1 w1 w2 w3;所有的存取操作都针对同一个内存位置,r/w代表读/写,数字代表发出该操作的处理器。假设所有高速缓存在开始时是空的,并且使用下面的性能模型:读/写高速缓存命中,代价1个时钟周期;缺失引起简单的总线事务(如BusUpgr,BusUpd),60个时钟周期;缺失引起整个高速缓存块传输,90时钟周期。假设所有高速缓存是写回式。答:读写命中、总线事务、块传输分别简记为H、B、T。MESI协议:BTH H H H BTH BH H H BTH BH H H 共5B+12H+3T=582时钟周期BTH BTH B
10、TH BH BTH BTH BTH BTH H BH BTH 共10B+12H+8T=1330时钟周期BTH BTH BTH H BH H H H BTH BTH共6B+10H+4T=730时钟周期。Dragon协议:BTH H H H BTH BTH H BTH BTH BTH H BTH 共7B+12H+7T=882时钟周期BTH BTH BTH BTH BTH BTH H H H H BTTH BTH 共8B+12H+8T=1212时钟周期BTH BTH BTH H BTH BTH BTH BTH BTH BTH 共9B+10H+9T=1360时钟周期。由结果得出,、序列用MESI协议时
11、间更少,而序列用Dragon协议时间更少。综上可知,如果同一块在写操作之后频繁被多个核读操作采用Dragon协议更好一些,因为Dragon协议写操作后会更新其它核副本。如果一个同多次连续对同一块进行写操作MESI协议更有效,因为它不需要更新其它核副本,只需要总线事务无效其它核即可。4.5考虑以下代码段,说明在顺序一致性模型下,可能的结果是什么?假设在代码开始执行时,所有变量初始化为0。a. P1P2P3A=1U=AV=BB=1W=Ab.P1P2P3P4A=1U=AB=1W=BV=BX=A答:顺序一致性模型性下,保护每个进程都按程序序来发生内存操作,这样会有多种可能结果,这里假设最简单情况,即P
12、1、P2、P3依次进行。则a中U = V = W = 1,b中U=X=W=1,V=0。4.6 参照4.6.1中讨论多级高速缓存包含性的术语,假设L1和L2都是2-路组相联,n2n1,b1=b2,且替换策略用FIFO来代替LRU,试问包含性是否还是自然满足?如果替换策略是随机替换呢?答:如果采用FIFO替换策略包含性自然满足,因为L1和L2都是2路组相联,FIFO保证了L1与L2在发生替换时会换出相同的缓存块,维护了包含性。如果采取随机替换策略,存在L1与L2替换不是相同块的情况,故不满足包含性。4.7 针对以下高速缓存情况,试给出一个使得高速缓存的包含性不满足的内存存取序列?L1 高速缓存容量
13、32字节,2-路组相联,每个高速缓存块8个字节,使用LRU替换算法;L2 高速缓存容量128字节,4-路组相联,每个高速缓存块8个字节,使用LRU替换算法。答:假设m1、m2、m3块映射到一级Cache和二级Cache的同一组中,考虑如下内存存取序列Rm1,Rm2,Rm1,Rm3,由LRU替换算法知道,当Rm3执行后,L1中被替换出的是m2,L2中被替换出的是m1,此时m1块在L1却不在L2中,不满足包含性。4.8 在4.6中关于分事务总线的讨论中,依赖于处理器与高速缓存的接口,下面情况有可能发生:一个使无效请求紧跟在数据响应之后,使得处理器还没有真正存取这个高速缓存块之前,该高速缓存块就被使
14、无效了。为什么会发生这种情况,如何解决?答:考虑如下情景:SMP目录一致性协议中,核1读缺失请求数据块A,主存响应请求传送数据块A给核1,同时核2对数据块A进行写操作,到主存中查得核1拥有副本,向核1发使无效请求。如此,一个使无效请求紧跟在数据响应之后。解决方法,可以使每个核真正存取高速缓存块后向主存发回应,然后再允许其它对此块操作的使无效或其它请求。4.9 利用LL-SC操作实现一个Test&Set操作。答:Test&Set: ll reg1,location /*Load-locked the location to reg1 */ bnz reg1,lock /* if locatin
15、was locked,try again*/ mov reg2,1 /*set reg2 1*/ sc location,reg2 /*store reg2 conditional into location*/4.10 在4.7.4部分描述具有感觉反转的路障算法中,如果将Unlock语句不放在if条件语句的每个分支中,而是紧接放在计数器增1语句后,会发生什么问题?为什么会发生这个问题?答:再进入下一个路障时可能会发生计数器重新清0现象,导致无法越过路障。考虑如下情景:第一次进入路障时,最后两个进入路障的进程分别为1、2。假设最后进入路障的进程为2进程,2进程执行共享变量加一操作并解锁。然后2
16、进程执行一条if条件语句,此时由于某种原因换出或睡眠,而此时共享变量的值已经为p。如果1进程此时正执行if条件语句,则清零计数器,设置标志,其它进程越过路障。到目前为止没有出现问题,问题出现在下一次进入路障。进程再一次进入路障,此时会执行共享变量加一操作。如果此时2进程被换入或被唤醒,会重新清零共享变量,使之前到达路障的进程的加一操作无效,导致无法越过路障。第五章 大规模并行处理机系统5.1简述大规模并行处理机的定义,原理和优点?答:并行处理机有时也称为阵列处理机,它使用按地址访问的随机存储器,以单指令流多数据流方式工作,主要用于要求大量高速进行向量矩阵运算的应用领域。并行处理机的并行性来源于
17、资源重复,它把大量相同的处理单元(PE)通过互联网络(ICN)连接起来,在统一的控制器(CU)控制下,对各自分配来的数据并行地完成同一条指令所规定的操作。PE是不带指令控制部件的算术逻辑运算单元。并行处理机具有强大的向量运算能力,具有向量化功能的高级语言编译程序有助于提高并行处理机的通用性,减少编译时间。5.2并行处理机有两种基本结构类型,请问是哪两种?并作简单介绍。答:采用分布存储器的并行处理结构和采用集中式共享存储器的并行处理结构。分布式存储器的并行处理结构中,每一个处理机都有自己的存储器,只要控制部件将并行处理的程序分配至各处理机,它们便能并行处理,各自从自己的存储器中取得信息。而共享存
18、储多处理机结构中的存储器是集中共享的,由于多个处理机共享,在各处理机访问共享存储器时会发生竞争。因此,需采取措施尽可能避免竞争的发生。5.3简单说明多计算机系统和多处理机系统的区别。答:他们虽然都属于多机系统但是他们区别在于:(1)多处理机是多台处理机组成的单机系统,多计算机是多台独立的计算机。(2)多处理机中各处理机逻辑上受同一的OS控制,而多计算机的OS逻辑上独立.(3)多处理机间以单一数据,向量。数组和文件交互作用,多计算机经通道或者通信线路以数据传输的方式进行。(4)多处理机作业,任务,指令,数据各级并行,多计算机多个作业并行。5.4举例说明MPP的应用领域及其采用的关键技术。答:全球
19、气候预报,基因工程,飞行动力学,海洋环流,流体动力学,超导建模,量子染色动力学,视觉。采用的关键技术有VLSI,可扩张技术,共享虚拟存储技术。5.5多处理机的主要特点包括答:(1) 结构的灵活性。与SIMD计算机相比,多处理机的结构具有较强的通用性,它可以同时对多个数组或多个标量数据进行不同的处理,这要求多处理机能够适应更为多样的算法,具有灵活多变的系统结构。2) 程序并行性。并行处理机实现操作一级的并行,其并行性存在于指令内部,主要用来解决数组向量问题;而多处理机的并行性体现在指令外部,即表现在多个任务之间。3) 并行任务派生。多处理机是多指令流操作方式,一个程序中就存在多个并发的程序段,需
20、要专门的程序段来表示它们的并发关系以控制它们的并发执行,这称为并行任务派生。4) 进程同步。并行处理机实现操作级的并行,所有处于活动状态的处理单元受一个控制器控制,同时执行共同的指令,工作自然同步;而多处理机实现指令、任务、程序级的并行,在同一时刻,不同的处理机执行着不同的指令,进程之间的数据相关和控制依赖决定了要采取一定的进程同步策略。5.6在并行多处理机系统中的私有Cache会引起Cache中的内容相互之间以及与共享存储器之间互不相同的问题,即多处理机的Cache一致性问题。请问有哪些原因导致这个问题?答:1) 出现Cache一致性问题的原因主要有三个:共享可写的数据、进程迁移、I/O传输
21、。共享可写数据引起的不一致性。比如P1、P2两台处理机各自的本地高速缓冲存储器C1、C2中都有共享存储器是M中某个数据X的拷贝,当P1把X的值变成X/后,如果P1采用写通过策略,内存中的数据也变为X/,C2中还是X。如果通过写回策略,这是内存中还是X。在这两种情况下都会发生数据不一致性。2) 进程迁移引起的数据不一致性。P1中有共享数据X的拷贝,某时刻P1进程把它修改为X/并采用了写回策略,由于某种原因进程从P1迁移到了P2上,它读取数据时得到X,而这个X是“过时”的。3) I/O传输所造成的数据不一致性。假设P1和P2的本地缓存C1、C2中都有某数据X的拷贝,当I/O处理机将一个新的数据X/
22、写入内存时,就导致了内存和Cache之间的数据不一致性。5.7分别确定在下列两种计算机系统中,计算表达式所需的时间:s=A1*B1+A2*B2+A4*B4。 a) 有4个处理器的SIMD系统;b) 有4个处理机的MIMD系统。假设访存取指和取数的时间可以忽略不计;加法与乘法分别需要2拍和4拍;在SIMD和MIMD系统中处理器(机)之间每进行一次数据传送的时间为1拍;在SIMD系统中,PE之间采用线性环形互连拓扑,即每个PE与其左右两个相邻的PE直接相连,而在MIMD中每个PE都可以和其它PE有直接的的通路。答:假设4个PE分别为PE0,PE1,PE2,PE3。利用SIMD计算机计算上述表达式,
23、4个乘法可以同时进行,用时=4个时间单位;然后进行PE0到PE1,PE2到PE3的数据传送,用时=1个时间单位。在PE1和PE3中形成部分和,用时=2个时间单位。接着进行PE1到PE3的部分和传送,用时=1*2=2个时间单位。最后,在PE3中形成最终结果,用时=2个时间单位。因此,利用SIMD计算机计算上述表达式总共用时=4(乘法)+1(传送)+2(加法)+2(传送)+2(加法)=11个时间单位。而利用MIMD计算机计算上述表达式,除了在第二次传送节省1个时间单位以外,其他与SIMD相同。因此用时=4(乘法)+1(传送)+2(加法)+1(传送)+2(加法)=10个时间单位。5.8假定有一个处理
24、机台数为p的共享存储器多处理机系统。设m为典型处理机每条执行执行时间对全局存储器进行访问的平均次数。设t为共享存储器的平均存储时间,x为使用本地存储器的单处理机MIPS速率,再假定在多处理机上执行n条指令。现在假设p=32,m=0.4,t=1s,要让多处理机的有效性能达到56MIPS,需要每台处理机的MIPS效率是多少?A.2B.4C.5.83D.40答:B5.9试在含一个PE的SISD机和在含n个PE且连接成一线性环的SIMD机上计算下列求内积的表达式:其中n=2k假设完成每次ADD操作需要2个单元时间,完成每次MULTIPLY操作需要4个单位时间,沿双向环在相邻PE间移数需1个单位时间(1
25、) SISD计算机上计算s需要多少时间(2) SIMD计算机上计算s需要多少时间(3) SIMD机计算s相对于SISD计算的加速比是多少?答:(1) 4n+2(n-1)(2)(3)5.10如果一台SIMD计算机和一台流水线处理机具有相同的计算性能,对构成它们的主要部件分别有什么要求?答:一台具有n个处理单元的SIMD计算机与一台具有一条n级流水线并且时钟周期为前者1/n的流水线处理机的计算性能相当,两者均是每个时钟周期产生n个计算结果。但是,SIMD计算机需要n倍的硬件(n个处理单元),而流水线处理机中流水线部件的时钟速率要求比前者快n倍,同时还需要存储器的带宽也是前者的n倍。第六章 机群系统
26、6.1 试区分和例示下列关于机群的术语:1)专用机群和非专用机群;2)同构机群和异构机群;3)专用型机群和企业型机群。答:1) 根据节点的拥有情况,分为专用机群和非专用机群,在专用机群中所有的资源是共享的,并行应用可以在整个机群上运行,而在非专用机群中,全局应用通过窃取CPU时间获得运行,非专用机群中由于存在本地用户和远地用户对处理器的竞争,带来了进程迁移和负载平衡问题。2) 根据节点的配置分为同构机群和异构机群,同构机群中各节点有相似的的体系,并且使用相同的操作系统,而异构机群中节点可以有不同的体系,运行的操作系统也可以不同。3) 专用型机群的特点是紧耦合的、同构的,通过一个前端系统进行集中
27、式管理,常用来代替传统的大型超级计算机系统;而企业型机群是松耦合的,一般由异构节点构成,节点可以有多个属主,机群管理者对节点有有限的管理权。6.2 试解释和例示一下有关单一系统映像的术语:1)单一文件层次结构;2)单一控制点;3)单一存储空间;4)单一进程空间;5)单一输入/输出和网络。答:1) 用户进入系统后所见的文件系统是一个单一的文件和目录层次结构,该系统透明的将本地磁盘、全局磁盘和其他文件设备结合起来。2) 整个机群可以从一个单一的节点对整个机群或某一单一的节点进行管理和控制。3) 将机群中分布于各个节点的本地存储器实现为一个大的、集中式的存储器。4) 所有的用户进程,不管它们驻留在哪
28、个节点上,都属于一个单一的进程空间,并且共享一个统一的进程识别方案。5) 单一输入/输出意味着任何节点均可访问多个外设。单一网络是任一节点能访问机群中的任一网络连接。6.3 就Solaris MC系统回答下列问题:1)Solaris MC 支持习题6.2 中单一系统映像的哪些特征?不支持哪些特征?2)对那些Solaris MC 支持的特征,解释一下Solaris MC是如何解决的。答:1) 支持单一文件层次结构、单一进程空间、单一网络和单一I/O空间。不支持单一控制点和单一的存储空间。2) Solaris使用了一个叫PXFS的全局文件系统GFS。PXFS文件系统的主要特点包括:单一系统映像、一
29、致的语义及高性能。PXFS通过在VFS/vnode接口上截取文件访问操作实现单一系统映像,保证了单一文件层次结构。Solaris MC提供了一个全局进程标示符pid可定位系统所有进程,一个进程可以迁移到其他节点,但它的宿主节点中总记录有进程的当前位置,它通过在Solaris核心层上面增加一个全局进程以实现单一进程空间,每个节点有一个节点管理程序,每个本地进程有一个虚拟进程对象vproc,vproc保留每个父进程和子进程的信息,实现了全局进程的管理。单一网络和I/O空间通过一致设备命名技术和单一网络技术实现。6.4 举例解释并比较以下有关机群作业管理系统的术语:1)串行作业与并行作业;2)批处理
30、作业与交互式作业;3)机群作业和外来作业;4)专用模式、空间共享模式、时间共享模式;5)独立调度与组调度。答:1) 串行作业在单节点上运行,并行作业使用多个节点。2) 批处理作业通常需要较多的资源,如大量的内存和较长的CPU时间,但不需要迅速的反应;交互式作业要求较快的周转时间,其输入输出直接指向终端设备,这些工作一般不需要大量资源,用户期望它们迅速得到执行而不必放入队列中。3) 机群作业时通过使用JMS功能分布实现的用户作业,用户服务器位于任一主机节点,资源管理器跨越所有的机群节点。外来作业在JMS之外生成的,如NOW上的一个工作站拥有者启动的外部作业,它不提交给JMS。4) 专用模式:任一
31、时候只有一个作业在机群上运行,任一时候也只有一个作业进程分配给一个节点。空间共享模式:多个作业可以在不重叠的节点区域上运行。时间共享模式:在专用模式和空间共享模式下,只有一个用户进程分配给一个节点,但是所有的系统进程或监护程序仍在同一个节点上运行。 5) 独立调度:各节点OS进行自己的调度,但这会显著损坏并行作业的性能,因为并行作业的进程间需要交互。组调度:将并行作业的所有进程一起调度。一个进程激活时,所有进程都被激活。6.5 针对LSF回答下列问题:1)对LSF的四种作业类型各举一个例子;2)举一个例子说明外来作业;3)对一个有1000个服务器的机群,为什么LSF负载分配机制优于:1整个机群
32、只有一个LIM或者2所有LIM都是主机?说明原因。答:1) 交互式:用户使用lshosts命令就可以列出每个服务器节点的静态资源,实现交互。批处理:lsbatch实用程序允许通过LSF提交、监控和执行批处理作业。串行:用户一旦进入lstcsh shell,发送的每条命令自动在最适合的节点上执行。并行:lsmake实用程序是UNIX make实用程序时一个并行版本,允许在多个节点同时处理一个Makefile。2) 不通过LSF执行的称为外来作业。例如执行一些本地作业:字处理,web网络浏览等。3) 机群的服务器数目太多,如果只采用一个LIM会导致LIM的负责过重,不能及时的处理响应所有服务器的请
33、求和分派所有机群作业;如果采用2会导致LIM之间相互交换负载信息过多,导致网络通信量过大。6.6 为什么在分布式文件系统中,UNIX语义难以实现?有哪些放松的文件共享语义?采用放松的文件共享语义会有一些什么缺点?答:在UNIX语义中,一个修改过的块应该立刻被所有其他应用程序见到。然而分布式的文件系统中,多个节点可能存放了同一文件块的拷贝,当其中一个节点修改文件可的拷贝时,其他节点不能立刻就知道,这就使得UNIX语义难以实现。放松的文件共享语义有:对话语义、类事物语义、不可改变的共享文件语义等。采用放松的文件共享语义要求应用程序员修改程序代码,以适用这种新的语义,这就增加了程序员的负担。6.7
34、试解释在机群并行文件系统中,为什么采用软件RAID、高速缓存机制和预取能够提高文件系统性能。答:软件RAID是文件系统负责分布数据和维护容错级别,能够和RAID5有一样的性能,实现机群磁盘间的数据分布,提高了I/O系统的传输带宽。高速缓存是将应用程序要取的块放在CACHE中,根据局部性原理,应用程序可以基本上从CACHE中读取数据块,而不要通过读取内存或硬盘,提高了读取速度。预取是在真正读取数据块之前就将这些数据块读入内存,这也提高了I/O性能,改善了文件系统性能。6.8 讨论并行文件系统协作化高速缓存的基本技术前提是什么?这个前提有什么意义?答:基本技术前提是互联网络的速度很快,一个节点需要
35、的文件块在其他节点的缓存中,那么就不需要从磁盘读,而是直接从其他节点的缓存中读出。这个前提的意义是可以提高系统的性能,使得节点间的协作化缓存变得更有意义。6.9 回答以下关于Berkeley NOW项目的问题:1)Berkeley NOW项目支持单一系统映像的哪几个方面?即单入口点、单文件层次结构、单控制点、单存储空间、单进程空间哪个的哪几项?并解释如何支持。2)解释Berkeley NOW项目用来提高性能的四个结构特征。3)解释Berkeley NOW项目和SP机群四个体系结构的差异,并讨论各自的优点。答:1) 通过用户级整个机群软件GLUNIX,提供单一系统映像。开发了一种新的无服务器网络
36、文件系统xFS,以支持单一文件层次结构。2) 主动消息通信协议,支持有效的通信;机群软件GLUNIX提供单一的系统映像、资源管理和可用性;xFS支持可扩放性和单一文件层次结构的高可用性;软件框架WebOS构筑高可用性、渐增可扩放性。3) SP机群的体系结构特征:每个节点都是RS/600工作站,并有自己的局部磁盘;每个节点内驻留一个完整的AIX;各节点通过其I/O总线连接到专门设计的多级高速网络;尽量使用标准工作站部件。这样的优点是简单性和灵活性。6.10考虑xFS,并回答下列问题:1)解释xFS和集中式文件服务器的两个不同点,并讨论各自的优点;2)解释xFS用来提高可用性的主要技术;3)解释x
37、FS用来减轻小写问题的主要技术。答:1) 无服务器文件系统xFS将文件服务的功能分布到机器的所有节点上,xFS中所有的服务器和客户的功能由分散的所有节点实现之。这与集中文件服务器的中央存储、中央缓存、中央管理不同。xFS的优点是采用分布式管理和协同文件缓存以及冗余磁盘阵列,这提高了系统的可用性以及I/O的性能和吞吐量。集中式文件服务器会减少缓存的不一致性,管理简单。2) xFS提高可用性的主要技术是采用廉价冗余磁盘阵列RAID。无工作站文件系统能用来生成软件RAID,以提高性能和高可用性。现在xFS使用单奇偶校验磁盘条。一个文件数据块在多个存储服务器节点上按条划分,在另一个节点上有奇偶校验块。
38、如果一个节点失效,失效磁盘的内容,可利用其余盘和奇偶盘之异或操作重建之。3) xFS使用日志条的方法解决小写问题:每个用户首先将写接合到各用户的日志上;然后此日志采用日志段提交给磁盘,每个段系由K-1个日志片组成,它与奇偶校验片以道送给K个存储服务器。第七章 分布式共享存储系统7.1什么是分布式共享存储系统,它相对于共享存储系统与分布式系统有哪些优点?答:分布式共享存储系统,是把共享存储器分成许多模块并分布于各处理机之中。分布式系统中采用消息传递通信,性能提高了,但多地址空间不利于程序员编程。共享存储系统支持传统的单地址空间,但共享必然引起冲突,形成瓶颈,于是分布式共享存储系统结合两者的优点。
39、7.2释放一致性模型(RC)把处理器一致性(PC)和弱一致性模型(WC)的优点结合在一起了。试回答下面有关这些一致性模型的问题:a) 比较这三种一致性模型的实现要求。b)评论每种一致性模型的优缺点。答:a)处理器一致性要求:在任一取数操作LOAD允许被执行之前,所有在同一处理器中先于这一LOAD的取数操作都已完成;在任一存数操作STORE允许执行之前,所有在同一处理器中先于这一STORE的访存操作(包括取数操作和存数操作)都已完成。弱一致性模型要求:同步操作的执行满足顺序一致性条件;在任一普通访存操作允许被执行之前,所有在同一处理器中先于这一访存操作的同步操作都已完成;在任一同步操作允许被执行
40、之前,所有在同一处理器中先于这一同步操作的普通访存操作都已完成。释放一致性模型要求:在任一普通访存操作允许被执行之前,所有在同一处理器中先于这一访存操作的获取操作acquire都已完成;在任一释放操作release允许被执行之前,所有在同一处理器中先于这一release的普通访存操作都已完成;同步操作的执行满足顺序一致性条件。b)三种模型对存储顺序要求逐渐降低,可优化程度逐渐增加,但是对程序员的要求也越来越高,所以释放性一致性是性能与复杂度的折中。7.3在DSM系统的顺序一致性存储模型下,有三个并行执行的进程如下所示,试问是不是一个合法的输出?并加以解释。P1P2P3A=1;B=1;C=1;P
41、rint(b,c);Print(a,c);Print(a,b);答:不是一个合法输出。考虑顺序一致性存储模型,每个进程的程序序会被维护,那么无论哪个进程最后执行Print语句,则之前的A=1,B=1,C=1都已经完成,所以输出的两后两项必为11,所以不是合法输出。7.4试分类下面来自三个处理器的引用流的高速缓存缺失。假设每一个处理器的高速缓存只有一个4个字的高速缓存行,字W0到W3、W4到W7分别处于同一个高速缓存行。 如果一行有多个引用,我们假设P1在P2之前发射、P2在P3之前发射内存引用,符号 LD/ST Wi表示LOAD/STORE 字i。操作序号P1P2P31ST W0ST W72L
42、D W6LD W23LD W74LD W2LD W05ST W26LD W27ST W2LD W5LDW58ST W59LD W3LD W710LD W6LD W211LD W2ST W712LD W713LD W214LD W515LD W2答:操作序号3、6、8、12-15都是单操作。操作序号1、2、9-11为无关存储操作,由于不在同一块中。操作序号4、7为对同一缓存块的连续两次LD,需要按序进行。7.5假设系统中共有512个处理器和1GB主存,每个节点内有8个处理器对目录可见,一个高速缓存行的大小为64字节,那么在(a) 满位向量方案和(b) DriB(i=3)模型下目录的存储成本各是多
43、少?答:分别为总容量的12.%和5.47%。7.6 细数一下中心目录与分布式目录方案的实现方法与各自的使用情况。答:中心目录是用一个中心目录存放所有高速缓存目录的拷贝,中心目录能提供为保证一致性所需要的全部信息。因此,其容量非常大且必须采用联想方法进行检索,这和单个高速缓存的目录类似。大型多处理机系统采用中心目录会有冲突和检索时间过长两个缺点。分布式目录方案是由Censier和Feautrier提出来。在分布式目录中每个存储器模块维护各自的目录,目录中记录着每个存储器块的状态和当前的信息,其中状态信息是本地的,而当前信息指明哪些高速缓存中有该存储器块的拷贝。一般来说,在共享存储上实现中心目录,
44、而在分布式系统上实现分布式目录方案更为合适一些,但这也并不是绝对的。7.7在研究DSM的读写代价和实现问题时有这样两种算法,即中央服务器算法和迁移算法:中央服务器算法是指使用一个中央服务器,负责为所有对共享数据的访问提供服务并保持共享数据唯一的副本;迁移算法是指要访问的数据总是被迁移到访问它的节点中。两种算法图示如下:中央服务器算法顾客中央服务器发送数据请求接收请求执行数据访问,发送应答接收应答迁移算法顾客远程主机如果高速缓存行不在本地,则确定位置,发送请求接收请求,发送高速缓存行接收回答,访问数据现假设报文数量不会导致网络阻塞,服务员的阻塞没有严重到能够极大地延迟远程进程访问,访问本地数据的
45、代价与远程访问代价相比微不足道,报文传递也是可靠的。试分析两种算法的适合情况。答:中央服务器算法,每次顾客发送数据请求到中央服务器,地址计算简单,适合多个顾客频繁轮流读写。迁移算法每次确定位置需要一定开销,适用于单个顾客频繁对数据读写,因为访问数据总是被迁移到访问节点里。7.8下面是运行在一个硬件维护高速缓存一致性的多处理机上的程序段,假设所有值初始 为0。 P1 P2 P3 P4 A=1 U=A W=A A=2 V=A X =A 只有一个共享变量A, 假设一个用户知道所有高速缓存拷贝的地址并且可直接对(不需要和目录节点协商)拷贝进行更新,假设采用写更新协议。试构造出一个写原子性被违背的情况:说明产生的结果违背了顺序一致性;答:如果进程P1首先对含有共享变量A的数据块进行写操作,进程P2、P3执行U=A和W=A,分别将U、W置为1。此时P4对共享变量A进行写操作,并且同时更新P1、P2、P3中的值,此后P2、P3再执行V=A,X=A,此时V与X被置为了2。对于进程2来说,结果违背了顺序一致性。7.9参照下述代码段:问:是不是PARM一致性内存模型的合法输出?解释原因说明顺序一致性与PARM一致性区别? a=1; b=1; c=1; Print(b, c); Print(a, c); Print(a, b); (a)P1 (b)
限制150内