缓冲技术55驱动调度技术设备培训课件_第1页
缓冲技术55驱动调度技术设备培训课件_第2页
缓冲技术55驱动调度技术设备培训课件_第3页
缓冲技术55驱动调度技术设备培训课件_第4页
缓冲技术55驱动调度技术设备培训课件_第5页
已阅读5页,还剩45页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

5.4缓冲技术

5.4.1单缓冲5.4.2双缓冲5.4.3多缓冲第一页,共五十页。5.4缓冲技术(1)

引入缓冲技术的目的•改善中央处理器与外围设备之间速度不配的矛盾,•协调逻辑记录大小与物理记录大小不一致,•提高CPU和I/O设备的并行性。第二页,共五十页。缓冲技术(2)

缓冲技术实现基本思想进程执行写操作输出数据时,向系统申请一个缓冲区,若为顺序写请求,则不断把数据填到缓冲区,直到被装满。此后,进程继续它的计算,系统将缓冲区内容写到I/O设备上。进程执行操作输入数据时,向系统申请一个缓冲区,系统将一个物理记录的内容读到缓冲区,根据进程要求,把当前需要的逻辑记录从缓冲区中选出并传送给进程。在输出数据时,只有在系统还来不及腾空缓冲而进程又要写数据时,它才需要等待;在输入数据时,仅当缓冲区空而进程又要从中读取数据时,它才被迫等待。

第三页,共五十页。5.4.1单缓冲

对于块设备,单缓冲机制如下工作:数据处理过程数据处理时间约为max[C,T]+M,

进程系统设备

TMC第四页,共五十页。5.4.2双缓冲(1)

输入数据时,首先填满缓冲区1,操作系统可从缓冲区1把数据送到用户进程区,用户进程便可对数据进行加工计算;与此同时,输入设备填充缓冲区2当缓冲区1空出后,输入设备再次向缓冲区1输入。操作系统又可把缓冲区2的数据传送到用户进程区,用户进程开始加工缓冲2的数据。第五页,共五十页。双缓冲(2)

传输和处理一块的时间(1)如果C<T,由于M远小于T,在将磁盘上的一块数据传送到缓冲区其间,计算机已完成将另一个缓冲区中的数据传送到用户区并对这块数据进行计算的工作,一块数据的传输和处理时间为T、即max(C,T),显然,这种情况下可保证块设备连续工作;第六页,共五十页。双缓冲(3)

传输和处理一块的时间(2)如果C>T,当上一块数据计算完毕后,需把一个缓冲区中的数据传送到用户区,花费时间为M,再对这块数据进行计算,花费时间为C,所以,一块数据的传输和处理时间为C+M、即max(C,T)+M,这种情况下进程不必要等待I/O。第七页,共五十页。双缓冲(4)

进程系统设备

(1)C<T,M<<Tmax(C,T)=T,保证设备连续工作。(2)C>T,M<<Tmax(C,T)+M=C+M,保证进程不等I/O。CMT第八页,共五十页。5.4.3多缓冲(1)

操作系统从主存区域中分配一组缓冲区组成循环缓冲,每个缓冲区的大小等于物理记录的大小。多缓冲的缓冲区是系统的公共资源,可供各个进程共享,并由系统统一分配和管理。缓冲区可用途分为:输入缓冲区,处理缓冲区和输出缓冲区。第九页,共五十页。5.5驱动调度技术(1)

5.5.1存储设备的物理结构5.5.2循环排序5.5.3优化分布5.5.4搜查定位5.5.5独立磁盘冗余阵列5.5.6提高磁盘I/O速度的一些方法第十页,共五十页。

驱动调度技术(2)

驱动调度和驱动调度算法。驱动调度能减少为若干个I/O请求服务所需的总时间,提高系统效率、除了I/O请求的优化排序外,信息在辅助存储器上的排列方式,存储空间分配方法都能影响存取访问速度。第十一页,共五十页。5.5.1存储设备的物理结构(1)

顺序存取存储设备是严格依赖信息的物理位置进行定位和读写的存储设备具有存储容量大、稳定可靠、卷可装卸和便于保存等优点■始点块1间隙块2间隙块3间隙块i间隙块i+1■末点…………磁头(正走,反走,正读,反读,正写,反写,倒带)第十二页,共五十页。存储设备的物理结构(2)

直接存取存储设备磁盘是一种直接(随机)存取存储设备。每个物理记录有确定的位置和唯一的地址,存取任何一个物理块所需的时间几乎不依赖于此信息的位置。访问磁盘记录参数:柱面号、磁头号、块号第十三页,共五十页。5.5.2循环排序(1)

考虑磁道保存4个记录的旋转型设备,假定收到四个I/O请求。请求次序记录号(1)读记录4(2)读记录3(3)读记录2(4)读记录11234第十四页,共五十页。循环排序(2)

多种I/O请求排序方法

•方法1:按照I/O请求次序读记录4、3、2、1,平均用1/2周定位,再加上1/4周读出记录,总处理时间等于3周,即60毫秒。

•方法2:如果次序为读记录1、2、3、4。总处理时间等于1.5周,即30毫秒。

•方法3:如果知道当前读位置是记录3,则采用次序为读记录4、1、2、3。总处理时间等于1周,即20毫秒。第十五页,共五十页。5.5.3优化分布(1)

考虑10个逻辑记录A,B……,J被存于旋转型设备上,每道存放10个记录,安排如下:

物理块逻辑纪录1-10A-J(ABCDE…..)处理10个记录的总时间10毫秒(移动到记录A的平均时间)+2毫秒(读记录A)+4毫秒(处理记录A)+9×[16毫秒(访问下一记录)+2毫秒(读记录)+4毫秒(处理记录)]=214毫秒

第十六页,共五十页。优化分布(2)

按照下面方式对信息优化分布

物理块逻辑纪录1A2H3E4B5I6F7C8J9G10D第十七页,共五十页。优化分布(3)

处理10个记录的总时间为10毫秒(移动到记录A的平均时间)+10×[2毫秒(读记录)×4毫秒(处理记录)]=70毫秒第十八页,共五十页。5.5.4交替地址

每个记录重复记录在设备的多个区域,读相同的数据,有几个交替地址,也称为多重副本或折迭。成功与否取决于下列因素:数据记录总是读出使用,不需修改写入;数据记录占用的存储空间总量不太大;数据使用极为频繁。第十九页,共五十页。5.5.5搜查定位(1)

移臂调度有若干策略(1)“电梯调度”算法(2)“最短查找时间优先”算法(3)“扫描”算法(4)“分步扫描”算法(5)“单向扫描”算法

第二十页,共五十页。搜查定位(2)

“电梯调度”算法

电梯调度算法有等待请求?结束请求与当前柱面相同?处理有最近块号的请求启动CC是向里或向外移?是否否向外向里有比当前柱面小的请求?改变移动方向A有比当前柱面大的请求?改变移动方向否否处理大于当前柱面号请求中柱面号最小的请求处理小于当前柱面号请求中的柱面号最大的请求移动磁头到指定柱面,登记当前位置启动CBBA第二十一页,共五十页。搜查定位(4)

“最短查找时间优先”算法

本算法考虑了各个请求之间的区别,总是先执行查找时间最短的那个磁盘请求,从而,较“先来先服务”算法有较好的寻道性能。

第二十二页,共五十页。搜查定位(5)

“扫描”算法

磁盘臂每次沿一个方向移动,扫过所有柱面,遇到最近的I/O请求便进行处理,直到最后一个柱面后,再向相反方向移动回来。

第二十三页,共五十页。搜查定位(6)

“分步扫描”算法

将I/O请求分成组,每组不超过N个请求,每次选一个组进行扫描,处理完一组后再选下一组。第二十四页,共五十页。搜查定位(7)

“循环扫描”算法

移动臂总从0号柱面至最大号柱面顺序扫描,然后,直接返回0号柱面重复进行,归途中不再服务,构成了一个循环。

第二十五页,共五十页。5.5.6独立磁盘冗余阵列(1)

独立磁盘冗余阵列是利用一台磁盘阵列控制器统一管理和控制一组磁盘驱动器,组成一个速度快、可靠性高、性能价格比好的大容量磁盘系统。RAID填补CPU速度快与磁盘设备速度慢之间的间隙,其策略是:第二十六页,共五十页。独立磁盘冗余阵列(2)

RAID共同特性

①RAID是一组物理磁盘驱动器,可被操作系统看作是单一逻辑磁盘驱动器;②数据被分布存储在阵列横跨的物理驱动器上;③冗余磁盘的作用是保存奇偶校验信息,当磁盘出现失误时它能确保数据的恢复。第二十七页,共五十页。

独立磁盘冗余阵列(3)

Strip0Strip4Strip8Strip12Strip1Strip5Strip9Strip13Strip10Strip3Strip7Strip15Strip10Strip11Strip2Strip6Strip14Strip10RAIDLevel0(1)第二十八页,共五十页。

Strip0Strip4Strip8Strip12Strip1Strip5Strip9Strip13Strip10Strip3Strip7Strip15Strip10Strip11Strip2Strip6Strip14Strip10DatamappingforaRAIDLevel0ArrayStrip0Strip1Strip2Strip3Strip4Strip5Strip6Strip7Strip8...ArrayManagementsoftware独立磁盘冗余阵列(4)RAIDlevel0(2)第二十九页,共五十页。

RAIDLevel1(Mirrored)Strip0Strip4Strip8Strip12Strip1Strip5Strip9Strip13Strip3Strip7Strip15Strip11Strip2Strip6Strip14Strip10Strip0Strip4Strip8Strip12Strip1Strip5Strip9Strip13Strip3Strip7Strip15Strip11Strip2Strip6Strip14Strip10独立磁盘冗余阵列(5)

RAIDlevel1第三十页,共五十页。

b0b1b2b3f0(b)f1(b)f2(b)RAIDLevel2(RedundancythroughHammingCode)独立磁盘冗余阵列(6)

RAIDlevel2第三十一页,共五十页。

b0b1b2b3P(b)RAIDLevel3(BitinterleavedParity)独立磁盘冗余阵列(7)RAIDlevel3第三十二页,共五十页。

block0block4block8block12block1block5block9block13block3block7block15block11block2block6block14block10P(0-3)P(4-7)90P(8-11)P(12-15)RAIDLevel4(BlocklevelParity)独立磁盘冗余阵列(8)

RAIDlevel4

第三十三页,共五十页。

独立磁盘冗余阵列(9)

RAIDlevel5block0block4block8block12block1block5block9P(12-15)block3P(4-7)block14block10block2block6block13P(8-11)P(0-3)block7Block11Block15block0block4block8block12RAIDLevel5(BlocklevelDistributedparity)第三十四页,共五十页。5.5.6提高磁盘I/O速度的方法

提前读延迟写虚拟盘

UNIX/Linux提供两种读盘和三种写盘方式:正常读-把磁盘块信息块读入主存缓冲区;提前读-读磁盘当前块时,下一磁盘块也读入主存缓冲区;正常写-把主存缓冲区中的信息写到磁盘块,且写进程应等待写操作完成;异步写-写进程无需等待写盘结束就可返回工作;延迟写-仅在缓冲区首部设置延迟写标志,然后,释放此缓冲区,并把该缓冲区链入空闲缓冲区链表的尾部,当其他进程申请到该缓冲区时,才真正把缓冲区信息写回磁盘块。第三十五页,共五十页。5.6设备分配

5.6.1设备独立性5.6.2设备分配和设备分配数据结构

第三十六页,共五十页。5.6.1设备独立性

通常用户不指定特定的设备,而指定逻辑设备,使得用户作业和物理设备独立开来,再通过其它途径建立逻辑设备和物理设备之间的对应关系,称这种特性为“设备独立性”。设备独立性带来的好处用户与物理的外围设备无关,系统增减或变更外围设备时程序不必修改;易于对付输入输出设备的故障。第三十七页,共五十页。5.6.2设备分配(1)

从设备的特性来看,可以把设备分成独占设备、共享设备和虚拟设备三类:相应的管理和分配外围设备的技术可分成:独占方式、共享方式和虚拟方式。常用的I/O设备分配算法先请求先服务,优先级高者先服务等。此外,在多进程请求I/O设备分配时,应防止因循环等待对方所占用的设备而产生死锁,应预先进行性检查。第三十八页,共五十页。设备分配(2)

I/O设备分配的实现(1)设备分配的数据结构:设备类表和设备表。系统中拥有一张设备类表,每类设备对应于表中一栏,包括内容有:设备类、总台数、空闲台数和设备表起始地址等。每一类设备都有各自的设备表,用来登记这类设备中每一台设备的状态,包含的内容有:物理设备名、逻辑设备名、占有设备的进程号、已分配/未分配、好/坏等。第三十九页,共五十页。设备分配(3)

I/O设备分配的实现(2)采用通道结构的系统中,设备分配的数据结构设置:系统设备表、通道控制表、控制器控制表和设备控制表。系统建立一张系统设备表,记录配置在系统中的所有物理设备的情况。每个通道、控制器、设备各设置一张表,记录各自的地址(标识符)、状态(忙/闲)、等待获得此部件的进程队列指针、及一次分配后相互勾链的指针,以备分配和执行I/O时使用。第四十页,共五十页。5.7虚拟设备5.7.1问题的提出5.7.2SPOOLING的设计和实现5.7.3SPOOLING应用例子第四十一页,共五十页。5.7.1问题的提出

静态分配方式是不利于提高系统效率采用脱机外围设备操作(SPOOLING)联机同时外围设备操作(又称作假脱机操作)第四十二页,共五十页。5.7.2斯普林系统的设计和实现(1)

“井”是用作缓冲的存储区域,采用井的技术能调节供求之间的矛盾,消除人工干预带来的损失。“预输入程序”“缓输出程序”“井管理程序”第四十三页,共五十页。

预输入程序作业1信息…作业n信息输入井作业1结果…作业n结果输出井缓输出程序井管理程序运行作业输入设备输出设备作业调度程序斯普林系统的设计和实现(2)

SPOOLING组成和结构

第四十四页,共五十页。斯普林系统的设计和实现(3)

输入井中作业状态

•输入状态:作业信息正在从输入设备上预输入;•收容收态:作业预输入结束,但未被选中执行;•执行状态:正在执行,可读数据也可以写数据;•完成状态:作业已经撤离,结果等待输出。第四十五页,共五十页。斯普林系统的设计和实现(4)

SPOOLING数据结构

•作业表登记进入系统的所有作业的作业名、状态、预输入表位置等信息。预输入表每个用户作业有一张用来登记该作业的各个文件的情

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论