缓冲区管理

1.缓冲区的引入
引入缓冲区的原因有很多,可归结为以下几点:
  (1) 缓和CPU与I/O设备间速度不匹配的矛盾。
  (2) 减少对CPU的中断频率,放宽对CPU中断响应时间的限制。
  (3) 解决数据粒度不匹配的问题。
  (4) 提高CPU和I/O设备之间的并行性。

2.单缓冲区和双缓冲区
单缓冲区(Single Buffer)
  在单缓冲情况下,每当用户进程发出一I/O请求时,操作系统便在主存中为之分配一缓冲区,如图所示。

双缓冲区(Double Buffer)
  缓冲区是共享资源,生产者与消费者在使用缓冲区时必须互斥,故而需要设置了两个缓冲区来提高效率。实现外部设备的并发。

如果在实现两台机器之间的通信时仅为它们配置了单缓冲,如图(a)所示,那么,它们之间在任一时刻都只能实现单方向的数据传输。例如,只允许把数据从A传送到B,或者从B传送到A,而绝不允许双方同时向对方发送数据。为了实现双向数据传输,必须在两台机器中都设置两个缓冲区,一个用作发送缓冲区,另一个用作接收缓冲区,如图(b)所示。

3.环形缓冲区
环形缓冲区的组成
  (1) 多个缓冲区。在环形缓冲中包括多个缓冲区,其每个缓冲区的大小相同。作为输入的多缓冲区可分为三种类型:用于装输入数据的空缓冲区R、已装满数据的缓冲区G以及计算进程正在使用的现行工作缓冲区C。

(2)多个指针。作为输入的缓冲区可设置三个指针:用于指示计算进程下一个可用缓冲区G的Nextg、指示输入进程下次可用的空缓冲区R的指针Nexti,以及用于指示计算进程正在使用的缓冲区C的指针Current。

进程之间的同步问题
  使用输入循环缓冲,可使输入进程和计算进程并行执行。相应地,指针Nexti和指针Nextg将不断地沿着顺时针方向移动,这样就可能出现下述两种情况:
  (1) Nexti指针追赶上Nextg指针。
  (2) Nextg指针追赶上Nexti指针。

4.缓冲池
缓冲池的组成
  缓冲池管理着多个缓冲区,每个缓冲区由用于标识和管理的缓冲首部以及用于存放数据的缓冲体两部分组成。缓冲首部一般包括缓冲区号、设备号、设备上的数据块号、同步信号量以及队列链接指针等。为了管理上的方便,一般将缓冲池中具有相同类型的缓冲区链接成一个队列,于是可形成以下三个队列:
  (1) 空白缓冲队列emq。
  (2) 输入队列inq。
  (3) 输出队列outq。

缓冲区的工作方式
  缓冲区可以工作在如下四种工作方式,如图所示。

磁盘存储器的性能和调度

1.磁盘性能简述
数据的组织和格式:盘片、面、磁道、扇区
为方便处理,每条磁道存储容量相同,每个磁道上的每个扇区相当于一个盘块。磁盘”格式化”的过程就是按规定的格式规划盘块

磁盘访问时间:设寻道时间为Ts,旋转延时Tr,传输时间Tt,访问时间Ta,启动磁臂时间s,磁头移动1条磁道所花时间 为m(常数),每次所读/写的字节数b,磁盘每秒转数r,则:
Ts=mn+s; Tr=1/(2r); Tt=b/(r*N); Ta=Ts+Tr+Tt;

2.磁盘调度算法
磁盘调度在多道程序设计的计算机系统中,各个进程可能会不断提出不同的对磁盘进行读/写操作的请求。由于有时候这些进程的发送请求的速度比磁盘响应的还要快,因此我们有必要为每个磁盘设备建立一个等待队列,常用的磁盘调度算法有以下四种:

  • 先来先服务算法(FCFS)
  • 最短寻道时间优先算法(SSTF)
  • 扫描算法(SCAN)
  • 循环扫描算法(CSCAN)

先来先服务算法(FCFS)First Come First Service
这是一种比较简单的磁盘调度算法。它根据进程请求访问磁盘的先后次序进行调度。此算法的优点是公平、简单,且每个进程的请求都能依次得到处理,不会出现某一进程的请求长期得不到满足的情况。
此算法由于未对寻道进行优化,在对磁盘的访问请求比较多的情况下,此算法将降低设备服务的吞吐量,致使平均寻道时间可能较长,但各进程得到服务的响应时间的变化幅度较小。

最短寻道时间优先算法(SSTF) Shortest Seek Time First
该算法选择这样的进程,其要求访问的磁道与当前磁头所在的磁道距离最近,以使每次的寻道时间最短,该算法可以得到比较好的吞吐量,但却不能保证平均寻道时间最短。
其缺点是对用户的服务请求的响应机会不是均等的,因而导致响应时间的变化幅度很大。在服务请求很多的情况下,对内外边缘磁道的请求将会无限期的被延迟,有些请求的响应时间将不可预期。

扫描算法(SCAN)电梯调度
扫描算法不仅考虑到欲访问的磁道与当前磁道的距离,更优先考虑的是磁头的当前移动方向。
例如,当磁头正在自里向外移动时,扫描算法所选择的下一个访问对象应是其欲访问的磁道既在当前磁道之外,又是距离最近的。这样自里向外地访问,直到再无更外的磁道需要访问才将磁臂换向,自外向里移动。这时,同样也是每次选择这样的进程来调度,即其要访问的磁道,在当前磁道之内,从而避免了饥饿现象的出现。
由于这种算法中磁头移动的规律颇似电梯的运行,故又称为电梯调度算法。此算法基本上克服了最短寻道时间优先算法的服务集中于中间磁道和响应时间变化比较大的缺点,而具有最短寻道时间优先算法的优点即吞吐量较大,平均响应时间较小,但由于是摆动式的扫描方法,两侧磁道被访问的频率仍低于中间磁道。

循环扫描算法(CSCAN)
循环扫描算法是对扫描算法的改进。如果对磁道的访问请求是均匀分布的,当磁头到达磁盘的一端,并反向运动时落在磁头之后的访问请求相对较少。这是由于这些磁道刚被处理,而磁盘另一端的请求密度相当高,且这些访问请求等待的时间较长,为了解决这种情况,循环扫描算法规定磁头单向移动。例如,只自里向外移动,当磁头移到最外的被访问磁道时,磁头立即返回到最里的欲访磁道,即将最小磁道号紧接着最大磁道号构成循环,进行扫描。

下面结合例子看一下,服务的顺序和计算磁头移动的总距离。
假设当前磁头在67号,要求访问的磁道号顺序为98,25,63,97,56,51,55,55,6 (电脑随机产生的,设定最外层磁道号为100号)

FIFO算法的服务序列是:98,25,63,97,56,51,55,55,6
磁头移动的总距离distance = (98-67)+(98-25)+(63-25)+(97-63)+(97-56)+(56-51)+(55-51)+(55-55)+(55-6)

SSTF算法的服务序列是: 63,56,55,55,51,25,6,97,98
磁头移动的总距离distance = (67-63)+(63-56)+(56-55)+(55-55)+(55-51)+(51-25)+(25-6)+(97-6)+(98-97)

SCAN算法的服务序列是:63,56,55,55,51,25,6,97,98
磁头移动的总距离distance = (67-63)+(63-56)+(56-55)+(55-55)+(55-51)+(51-25)+(25-6)+(97-6)+(98-97)

CSCAN算法的服务序列是(固定从外向里,此处设最外层为100):63,56,55,55,51,25,6,98,97
磁头移动的总距离distance = (67-63)+(63-56)+(56-55)+(55-55)+(55-51)+(51-25)+(25-6)+(100-98)+(98-97)

操作系统复习(十五)——缓冲区管理与磁盘调度算法相关推荐

  1. 操作系统(十五)调度算法的评价指标

    2.2.3 调度算法的评价指标 本节我们会简要的了解一些评价指标及其计算方法. CPU利用率 系统吞吐量 周转时间 等待时间 响应时间 CPU利用率 CPU利用率:指CPU "忙碌" ...

  2. Exchange Server2010系列之十五:Exchange磁盘压力测试

    本文章主要是使用Jetstress 2010测试Exchange的磁盘子系统,用来评估Exchange磁盘子系统的IO性能是否可以满足设计需求.Jetstress 工具通过与可扩展存储引擎 (ESE) ...

  3. 30天自制操作系统——第十五天实现多任务(一)

    任务切换 多任务(multitask)也可以称作多进程,在windows操作系统中,就是多个应用程序同时运行的状态. 这里来复习一下进程和线程的概念: 进程:进程是执行程序的一次执行过程,它是一个动态 ...

  4. 操作系统复习笔记(五)

    14.从"互斥","空闲让进","有限等待"3个方面讨论它的正确性.若正确,则证明之.若不正确,说明理由. program sample; ...

  5. 操作系统(十五)——mmap

    1. 概念 mmap是一种内存映射文件的方法,即将一个文件或者其它对象映射到进程的地址空间,实现文件磁盘地址和进程虚拟地址空间中一段虚拟地址的一一对映关系.实现这样的映射关系后,进程就可以采用指针的方 ...

  6. 基础复习十五、网络编程(2)

    什么是Socket通信 Socket(套接字)是主机中ip和端口结合,通过Socket可以轻松实现不同主机之间应用程序的通信,可以通俗的理解为不同主机中相同软件的的通信桥梁,关于计算机应用的通信模式分 ...

  7. 操作系统磁盘调度算法

    总返回目录 文章目录 缓冲管理 磁盘管理 N-step-SCAN算法 SSTF (离谁近就找谁算法) SCAN(坐电梯算法) 无特殊说明本片scan和c-scan默认为LOOK和C-look算法 缓冲 ...

  8. 《操作系统真象还原》第十五章 ---- 实现系统交互 操作系统最终章 四十五天的不易与坚持终完结撒花 (下)(遗憾告终)

    文章目录 专栏博客链接 相关查阅博客链接 本书中错误勘误 部分缩写熟知 实现exec的思路与启发 遗憾告终 专栏博客链接 <操作系统真象还原>从零开始自制操作系统 全章节博客链接 相关查阅 ...

  9. 操作系统:第四章 文件管理2 - 磁盘管理,磁盘调度算法

    本文已收录至 Github(MD-Notes),若博客中有图片打不开,可以来我的 Github 仓库:https://github.com/HanquanHq/MD-Notes,涵盖了互联网大厂面试必 ...

最新文章

  1. Silverlight游戏设计(Game Design):目录
  2. Python网络爬虫与信息提取(一)(入门篇)
  3. [bzoj1547]周末晚会
  4. 毕业5年跳槽24次,为什么这届95后换工作越来越勤?
  5. 关于工作[update]
  6. 【C++】非原创|统计代码覆盖率(一:C)
  7. 电机瞬态过程分析的MATLAB建模与仿,电机瞬态过程分析的MATLAB建模与仿真
  8. 彩虹易支付程序源码php,彩虹易支付聚合支付源码全解全网程序附对接接口教程...
  9. python如何添加标签_如何在python中为t-SNE添加标签(How to add labels to t-SNE in python)...
  10. Excel隔行插入空白行
  11. 织梦后台发布文章编辑器不显示的解决办法
  12. latex 字母上面加符号
  13. 华信短信视频开源平台搭建攻略(之三完结易错篇)
  14. oracle sqlplus建用户,Oracle用SQL Plus创建数据库表空间和用户
  15. c语言初学者学习所需软件
  16. ybt1223:An Easy Problem
  17. 未来智能家居方向是什么模式?小米?华为?智汀?
  18. java整合谷歌翻译
  19. 如何使用hardhat进行合约uups模式升级
  20. 2021全国计算机技术与软件专业技术资格水平考试(软考)网络管理员考试大纲

热门文章

  1. Welcome to 沐雪微信
  2. 高中的三角函数不会计算机,高中三角函数教学常见问题探析.doc
  3. mysql 主机免密登录设置
  4. linux oracle按钮乱码,oracle em 按钮乱码现象
  5. 游戏开发-unity 游戏性能优化
  6. Python中常用的第三方库
  7. 师范类需不要国家级计算机考证
  8. matlab 裕度指令,相位裕度增益裕度Matlab命令w=logspace-13.PPT
  9. java web项目中hibernate导入问题解决, AbstractInterceptor
  10. 老师生日c语言,C语言求解-小明和小强都是张老师的学生-张老师的生日是M月N日.doc...