处理机调度层次:
- 高级调度
长程调度,调度对象:作业 - 低级调度
短程调度,调度对象:进程 - 中级调度
内存调度,提高内存利用率和系统吞吐量
作业调度算法:
1. 先来先服务算法(first-come first-served,FCFS)
有利于长作业或CPU繁忙型作业
2. 短作业优先算法(short job first,SJF)
有利于短作业或I/O繁忙型作业
缺点:
- 必须预知作业的运行时间
- 忽视了作业的等待时间,可能世作业的等待时间过长,出现饥饿现象
- 人——机交互无法实现
- 不能保证紧迫作业及时得到处理
3. 优先级调度算法(priority-scheduling algorithm,PSA)
保证紧迫性作业优先运行
4. 高响应比优先算法(highest response ratio next,HRRN)
既考虑了短作业,又考虑了长作业
磁盘调度算法
先来先服务(FCFS)
方法:根据进程请求访问磁盘的先后顺序进行调度
优点:公平、简单,不会出现某一进程的请求长期得不到满足的情况
缺点:未对寻道进行优化,致使平均寻道时间可能较长
适用情况:请求磁盘I/O的进程数目较少
最短寻道时间优先(SSTF)
方法:访问的磁道与当前磁头所在的磁道距离最近
缺点:
- 不能保证平均寻道时间最短;
- 可能导致优先级低的进程发生饥饿现象
扫描算法(SCAN)
方法:优先考虑磁头当前移动方向,然后再考虑访问的磁道与当前磁头所在的磁道距离
循环扫描算法(CSCAN)
方法:磁头单向循环移动
N步SCAN算法(NStepSCAN)
方法:
将磁盘请求队列分成若干个长度为N的子队列,磁盘 调度按FCFS算法依次处理这些子队列,每处理一个队列按SCAN算法。当正在处理某队列时,若出现新的磁盘I/O请求,便将新请求进程放入其他队列优点:
不会出现“磁臂黏着”现象(有一个或几个进程对某一磁道有较高的访问频率,导致磁臂停留在某处不动的现象)
FSCAN算法
方法:
将磁盘请求队列分成2个子队列,一个是由当前所有请求磁盘I/O的进程形成的队列,由SCAN算法进行处理,另一个是在扫描期间,将新出现的所有请求磁盘I/O的进程放入等待处理的请求队列。

被折叠的 条评论
为什么被折叠?



