作业调度的主要功能是根据作业控制块中的信息,审查系统能否满足用户作业的资源需求,以及按照一定的算法,从外存的后备队列中北备杀商煤歌敌派曲选取某些作业调入内存,并为它们创建进程、分配必要的资源。然后再将新创建的进程插入就绪队列,记尼此市采境或准备执行。因此,有时也把作业调度称为接纳调度。
常用的作业调度算法有先来先服务、短作业优先、响应比高优先、优先级调度算法和均衡调度算法。
调度算法应该而做到:
1 、在单位时间内运行尽可能来自多的作业。
2 、使处理机保赶呀甚根却持忙碌的状态。
3 、使 I / O 设备得以充分360百科利用。
4 、对所有作业公平合理。
常用的作业调度算法有先来先服务、短作业优先、响应比高优先、优先级调度算法和均衡调度算法。
调度算法应该做到:
1 、在单位时间内运行尽可能多的作业。
2 、使处理机保持忙碌的状态。
3 、使 I / O 设备得以充分利用。
4 、对所来自有作业公平合理。
先来先服务(FCFS, First Come First Serve)是最简单的调度算法,按先后顺序进行调度。
360百科 按照作业提交或进程变为就绪状态的先后次序,分派CPU;
当阶够因委程新田战前作业或进程占用CPU,直到执行完或阻塞,才出让CPU(非抢占方式)。
在作业或进程唤醒后(如I/O庆操务调该火注备农的预完成),并不立即恢复执烧罗与呀印足尽某行,通常等到当前作业或进程出让CPU。
比较有利于长作业,而不利于短作业。
有利于CPU繁忙的作业,而不利于I/O繁忙的作业。
轮转法(Round Robin)是让每个进程在就绪队列中的等待时间与享受服务的时间成正比例。
将系统中航微所有的就绪进程按照FCFS原则,排成一个队列。
每次调度时将CPU分派给队首进程,让其执行一个时间道按扩片。时间片的长度从几个ms到几百ms。
在一个时间片结束时,发生时钟中断。
调度来自程序据此暂停当前进程的执行,将其送到就绪队列的末尾,并通过上下文切换执行当前的队首进程。
进程可以未使用完一个时间片,就出让CPU(如阻塞)。
时间片长度变化的影响
过长->退化为FCFS算法,进程在一个时间360百科片内都执行完,响应时间长。
过短->用户本板验的一次请求需要多个时甲脸培伯说晶叫说已女间片才能处理完,上下文切换次数增加,响应时间长。
对响应时间的要求:严弱往规松克T(响应时间)=N(进程数目)*q(时间片)
就绪进程的数目:数目越多,时间片越小
系统的处理能力:应当使用户输入通常在一个时间片内能处理完,否则段及粒换使响应时间,平均周转时间和平均带权周转时间延长。
多级在硫反馈队列算法(Round Robin with Multiple Feedback)是轮转算法和优先级算法的综合和发展。
设置多个就绪队列,分别赋予不同的优先级,如逐级降低,队列1的优先级最高。每个队列执行时间片的长度也不同,政规定优先级越低则时间片越长,如逐级防减远先加倍。
新进程进入内存后,先投入队列1的末尾,按FCF雷却儿蛋紧观多S算法调度;若按队列1一个时间片未能执行完,则降低投入到队列2的末尾,同样按FCFS算法调度;如此下去,降低到最后的队列,则按"时间片轮转"算法调度直到完成。
细上殖格仅升节 仅当较高优先级的队列为空,才调度较低优先推企逐些关务联将级的队列中的进程执李杆的赵独似引菜卷减行。如果进程执行其父建文晶子义沉有按时有新进程进入较高优先级的队列,则抢先执行新进程,并把被抢先零女吃角氧结旧肥的进程投入原队列的伯唱握女伤末尾。
为提高系统吞吐量和缩短平均周转时间而照顾短进程。
为获得较好的I/O两渐省黑差浓乱设备利用率和缩短响应时间而照顾I/O型进程。
不必估计进程的执行时间,动态调节
I/O型进程:让其进入最高优先级队列,以及时响应I/O交互。通常执行一个小时间片,要求可处理完一次I/O请求的数据,然后转入到阻塞队列。
计算型进程:每次都执行完时间片,进入更低级队列。最终采用最大时间片来执行,减少调度次数。
I/O次数不多,而主要是CPU处理的进程。在I/O完成后,放回优先I/O请求时离开的队列,以免每次都回到最高优先级队列后再逐次下降。
为适应一个进程在不同时间段的运行特点,I/O完成时,提高优先级;时间片用完时,降低优先级。
优先级算法(Priority Scheduling)是多级队列算法的改进,平衡各进程对响应时间的要求。适用于作业调度和进程调度,可分成抢先式和非抢先式。
作业调度中的静态优先级大多按以下原则确定:
由用户自己根据作业的紧急程度输入一个适当的优先级。
由系统或操作员根据作业类型指定优先级。
系统根据作业要求资源情况确定优先级。
进程的静态优先级的确定原则:
按进程的类型给予不同的优先级。
将作业的情态优先级作为它所属进程的优先级。
进程的动态优先级一般根据以下原则确定:
根据进程占用有CPU时间的长短来决定。
根据就绪进程等待CPU的时间长短来决定。
短作业优先(SJF, Shortest Job First)又称为"短进程优先"SPN(Shortest Process Next);这是对FCFS算法的改进,其目标是减少平均周转时间。
对预计执行时间短的作业(进程)优先分派处理机。通常后来的短作业不抢先正在执行的作业。
(1) 优点:
比FCFS改善平均周转时间和平均带权周转时间,缩短作业的等待时间;
提高系统的吞吐量;
(2) 缺点:
对长作业非常不利,可能长时间得不到执行;
未能依据作业的紧迫程度来划分执行的优先级;
难以准确估计作业(进程)的执行时间,从而影响调度性能。
"最短剩余时间优先"SRT(Shortest Remaining Time)(允许比当前进程剩余时间更短的进程来抢占)
"最高响应比优先"HRRN(Highest Response Ratio Next)(响应比R = (等待时间 + 要求执行时间) / 要求执行时间,是FCFS和SJF的折衷)
最高响应比优先法(HRN,Highest Response_ratio Next)是对FCFS方式和SJF方式的一种综合平衡。FCFS方式只考虑每个作业的等待时间而未考虑执行时间的长短,而SJF方式只考虑执行时间而未考虑等待时间的长短。因此,这两种调度算法在某些极端情况下会带来某些不便。HRN调度策略同时考虑每个作业的等待时间长短和估计需要的执行时间长短,从中选出响应比最高的作业投入执行。
响应比R定义如下: R =(W+T)/T = 1+W/T
其中T为该作业估计需要的执行时间,W为作业在后备状态队列中的等待时间。每当要进行作业调度时,系统计算每个作业的响应比,选择其中R最大者投入执行。这样,即使是长作业,随着它等待时间的增加,W / T也就随着增加,也就有机会获得调度执行。这种算法是介于FCFS和SJF之间的一种折中算法。由于长作业也有机会投入运行,在同一时间内处理的作业数显然要少于SJF法,从而采用HRN方式时其吞吐量将小于采用SJF 法时的吞吐量。另外,由于每次调度前要计算响应比,系统开销也要相应增加。