第三章-汤小丹-计算机操作系统-官方课件-第四版-计算机-操作系统--课件.pptx
《第三章-汤小丹-计算机操作系统-官方课件-第四版-计算机-操作系统--课件.pptx》由会员分享,可在线阅读,更多相关《第三章-汤小丹-计算机操作系统-官方课件-第四版-计算机-操作系统--课件.pptx(126页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、3.1 3.1 处理机调度的层次和调度算法的目标处理机调度的层次和调度算法的目标在多道程序系统中,调度的实质是一种资源分配,处理机调度是对处理机资源进行分配。处理机调度算法是指根据处理机分配策略所规定的处理机分配算法。在多道批处理系统中,一个作业从提交到获得处理机执行,直至作业运行完毕,可能需要经历多级处理机调度,下面先来了解处理机调度的层次。第1页/共126页3.1.1 3.1.1 处理机调度的层次处理机调度的层次1.1.高级调度高级调度(High Level Scheduling)(High Level Scheduling)2.2.低级调度低级调度(Low Level Schedulin
2、g)(Low Level Scheduling)3.3.中级调度中级调度(Intermediate Scheduling)(Intermediate Scheduling)第2页/共126页3.1.2 3.1.2 处理机调度算法的目标处理机调度算法的目标1.1.处理机调度算法的共同目标处理机调度算法的共同目标(1)资源利用率。为提高系统的资源利用率,应使系统中的处理机和其它所有资源都尽可能地保持忙碌状态,其中最重要的处理机利用率可用以下方法计算:第3页/共126页(2)公平性。公平性是指应使诸进程都获得合理的CPU 时间,不会发生进程饥饿现象。公平性是相对的,对相同类型的进程应获得相同的服务;
3、但对于不同类型的进程,由于其紧急程度或重要性的不同,则应提供不同的服务。(3)平衡性。由于在系统中可能具有多种类型的进程,有的属于计算型作业,有的属于I/O型。为使系统中的CPU和各种外部设备都能经常处于忙碌状态,调度算法应尽可能保持系统资源使用的平衡性。(4)策略强制执行。对所制订的策略其中包括安全策略,只要需要,就必须予以准确地执行,即使会造成某些工作的延迟也要执行。第4页/共126页2.2.批处理系统的目标批处理系统的目标(1)平均周转时间短。对每个用户而言,都希望自己作业的周转时间最短。但作为计算机系统的管理者,则总是希望能使平均周转时间最短,这不仅会有效地提高系统资源的利用率,而且还
4、可使大多数用户都感到满意。应使作业周转时间和作业的平均周转时间尽可能短。否则,会使许多用户的等待时间过长,这将会引起用户特别是短作业用户的不满。可把平均周转时间描述为:第5页/共126页为了进一步反映调度的性能,更清晰地描述各进程在其周转时间中,等待和执行时间的具体分配状况,往往使用带权周转时间,即作业的周转时间T与系统为它提供服务的时间Ts之比,即W=T/Ts。而平均带权周转时间则可表示为:第6页/共126页(2)系统吞吐量高。由于吞吐量是指在单位时间内系统所完成的作业数,因而它与批处理作业的平均长度有关。事实上,如果单纯是为了获得高的系统吞吐量,就应尽量多地选择短作业运行。(3)处理机利用
5、率高。对于大、中型计算机,CPU价格十分昂贵,致使处理机的利用率成为衡量系统性能的十分重要的指标;而调度方式和算法又对处理机的利用率起着十分重要的作用。如果单纯是为使处理机利用率高,应尽量多地选择计算量大的作业运行。由上所述可以看出,这些要求之间是存在着一定矛盾的。第7页/共126页3.3.分时系统的目标分时系统的目标(1)响应时间快。(2)均衡性。第8页/共126页4.4.实时系统的目标实时系统的目标(1)截止时间的保证。(2)可预测性。第9页/共126页3.2 3.2 作业与作业调度作业与作业调度在多道批处理系统中,作业是用户提交给系统的一项相对独立的工作。操作员把用户提交的作业通过相应的
6、输入设备输入到磁盘存储器,并保存在一个后备作业队列中。再由作业调度程序将其从外存调入内存。第10页/共126页3.2.1 3.2.1 批处理系统中的作业批处理系统中的作业1.1.作业和作业步作业和作业步(1)作业(Job)。(2)作业步(Job Step)。第11页/共126页2.2.作业控制块作业控制块(Job Control Block(Job Control Block,JCB)JCB)为了管理和调度作业,在多道批处理系统中,为每个作业设置了一个作业控制块JCB,它是作业在系统中存在的标志,其中保存了系统对作业进行管理和调度所需的全部信息。通常在JCB中包含的内容有:作业标识、用户名称、
7、用户账号、作业类型(CPU 繁忙型、I/O 繁忙型、批量型、终端型)、作业状态、调度信息(优先级、作业运行时间)、资源需求(预计运行时间、要求内存大小等)、资源使用情况等。第12页/共126页3.3.作业运行的三个阶段和三种状态作业运行的三个阶段和三种状态 作业从进入系统到运行结束,通常需要经历收容、运行和完成三个阶段。相应的作业也就有“后备状态”、“运行状态”和“完成状态”。(1)收容阶段。(2)运行阶段。(3)完成阶段。第13页/共126页3.2.2 3.2.2 作业调度的主要任务作业调度的主要任务 作业调度的主要任务是,根据JCB中的信息,检查系统中的资源能否满足作业对资源的需求,以及按
8、照一定的调度算法,从外存的后备队列中选取某些作业调入内存,并为它们创建进程、分配必要的资源。然后再将新创建的进程排在就绪队列上等待调度。因此,也把作业调度称为接纳调度(Admission Scheduling)。在每次执行作业调度时,都需做出以下两个决定。1.1.接纳多少个作业接纳多少个作业2.2.接纳哪些作业接纳哪些作业第14页/共126页3.2.3 3.2.3 先来先服务先来先服务(FCFS)(FCFS)和短作业优先和短作业优先(SJF)(SJF)调度算法调度算法 1.1.先来先服务先来先服务(first-come first-served(first-come first-served,
9、FCFS)FCFS)调度算法调度算法FCFS是最简单的调度算法,该算法既可用于作业调度,也可用于进程调度。当在作业调度中采用该算法时,系统将按照作业到达的先后次序来进行调度,或者说它是优先考虑在系统中等待时间最长的作业,而不管该作业所需执行时间的长短,从后备作业队列中选择几个最先进入该队列的作业,将它们调入内存,为它们分配资源和创建进程。然后把它放入就绪队列。第15页/共126页2.2.短作业优先短作业优先(short job first(short job first,SJF)SJF)的调度算法的调度算法 由于在实际情况中,短作业(进程)占有很大比例,为了能使它们能比长作业优先执行,而产生了
10、短作业优先调度算法。1)短作业优先算法SJF算法是以作业的长短来计算优先级,作业越短,其优先级越高。作业的长短是以作业所要求的运行时间来衡量的。SJF算法可以分别用于作业调度和进程调度。在把短作业优先调度算法用于作业调度时,它将从外存的作业后备队列中选择若干个估计运行时间最短的作业,优先将它们调入内存运行。第16页/共126页2)短作业优先算法的缺点SJF调度算法较之FCFS算法有了明显的改进,但仍然存在不容忽视的缺点:(1)必须预知作业的运行时间。在采用这种算法时,要先知道每个作业的运行时间。即使是程序员也很难准确估计作业的运行时间,如果估计过低,系统就可能按估计的时间终止作业的运行,但此时
11、作业并未完成,故一般都会偏长估计。(2)对长作业非常不利,长作业的周转时间会明显地增长。更严重的是,该算法完全忽视作业的等待时间,可能使作业等待时间过长,出现饥饿现象。第17页/共126页(3)在采用FCFS算法时,人机无法实现交互。(4)该调度算法完全未考虑作业的紧迫程度,故不能保证紧迫性作业能得到及时处理。第18页/共126页3.2.4 3.2.4 优先级调度算法和高响应比优先调度算法优先级调度算法和高响应比优先调度算法1.1.优先级调度算法优先级调度算法(priority-scheduling algorithm(priority-scheduling algorithm,PSA)PSA
12、)我们可以这样来看作业的优先级,对于先来先服务调度算法,作业的等待时间就是作业的优先级,等待时间越长,其优先级越高。对于短作业优先调度算法,作业的长短就是作业的优先级,作业所需运行的时间越短,其优先级越高。但上述两种优先级都不能反映作业的紧迫程度。第19页/共126页2.2.高响应比优先调度算法高响应比优先调度算法(Highest Response Ratio Next(Highest Response Ratio Next,HRRN)HRRN)在批处理系统中,FCFS算法所考虑的只是作业的等待时间,而忽视了作业的运行时间。而SJF算法正好与之相反,只考虑作业的运行时间,而忽视了作业的等待时间
13、。高响应比优先调度算法则是既考虑了作业的等待时间,又考虑作业运行时间的调度算法,因此既照顾了短作业,又不致使长作业的等待时间过长,从而改善了处理机调度的性能。第20页/共126页高响应比优先算法是如何实现的呢?如果我们能为每个作业引入一个动态优先级,即优先级是可以改变的,令它随等待时间延长而增加,这将使长作业的优先级在等待期间不断地增加,等到足够的时间后,必然有机会获得处理机。该优先级的变化规律可描述为:第21页/共126页由于等待时间与服务时间之和就是系统对该作业的响应时间,故该优先级又相当于响应比RP。据此,优先又可表示为:第22页/共126页3.3 3.3 进进 程程 调调 度度进程调度
14、是OS中必不可少的一种调度。因此在三种类型的OS中,都无一例外地配置了进程调度。此外它也是对系统性能影响最大的一种处理机调度,相应的,有关进程调度的算法也较多。第23页/共126页3.3.1 3.3.1 进程调度的任务、机制和方式进程调度的任务、机制和方式 1.1.进程调度的任务进程调度的任务进程调度的任务主要有三:(1)保存处理机的现场信息。(2)按某种算法选取进程。(3)把处理器分配给进程。第24页/共126页2.2.进程调度机制进程调度机制为了实现进程调度,在进程调度机制中,应具有如下三个基本部分,如图3-1所示。(1)排队器。(2)分派器。(3)上下文切换器。第25页/共126页图3-
15、1 进程调度机制第26页/共126页3.3.进程调度方式进程调度方式1)非抢占方式(Nonpreemptive Mode)在采用这种调度方式时,一旦把处理机分配给某进程后,就一直让它运行下去,决不会因为时钟中断或任何其它原因去抢占当前正在运行进程的处理机,直至该进程完成,或发生某事件而被阻塞时,才把处理机分配给其它进程。第27页/共126页2)抢占方式(Preemptive Mode)这种调度方式允许调度程序根据某种原则,去暂停某个正在执行的进程,将已分配给该进程的处理机重新分配给另一进程。在现代OS中广泛采用抢占方式,这是因为:对于批处理机系统,可以防止一个长进程长时间地占用处理机,以确保处
16、理机能为所有进程提供更为公平的服务。在分时系统中,只有采用抢占方式才有可能实现人机交互。在实时系统中,抢占方式能满足实时任务的需求。但抢占方式比较复杂,所需付出的系统开销也较大。第28页/共126页3.3.2 3.3.2 轮转调度算法轮转调度算法1.1.轮转法的基本原理轮转法的基本原理在轮转(RR)法中,系统将所有的就绪进程按FCFS策略排成一个就绪队列。系统可设置每隔一定时间(如30ms)便产生一次中断,去激活进程调度程序进行调度,把CPU分配给队首进程,并令其执行一个时间片。当它运行完毕后,又把处理机分配给就绪队列中新的队首进程,也让它执行一个时间片。这样,就可以保证就绪队列中的所有进程在
17、确定的时间段内,都能获得一个时间片的处理机时间。第29页/共126页2.2.进程切换时机进程切换时机在RR调度算法中,应在何时进行进程的切换,可分为两种情况:若一个时间片尚未用完,正在运行的进程便已经完成,就立即激活调度程序,将它从就绪队列中删除,再调度就绪队列中队首的进程运行,并启动一个新的时间片。在一个时间片用完时,计时器中断处理程序被激活。如果进程尚未运行完毕,调度程序将把它送往就绪队列的末尾。第30页/共126页3.3.时间片大小的确定时间片大小的确定在轮转算法中,时间片的大小对系统性能有很大的影响。图3-2示出了时间片大小对响应时间的影响,其中图(a)是时间片略大于典型交互的时间,而
18、图(b)是时间片小于典型交互的时间。图3-3示出了时间片分别为q=1和q=4时对平均周转时间的影响。第31页/共126页图3-2 时间片大小对响应时间的影响第32页/共126页图3-3 q=1和q=4时进程的周转时间第33页/共126页3.3.3 3.3.3 优先级调度算法优先级调度算法1.1.优先级调度算法的类型优先级调度算法的类型优先级进程调度算法,是把处理机分配给就绪队列中优先级最高的进程。这时,又可进一步把该算法分成如下两种。(1)非抢占式优先级调度算法。(2)抢占式优先级调度算法。第34页/共126页2.2.优先级的类型优先级的类型1)静态优先级静态优先级是在创建进程时确定的,在进程
19、的整个运行期间保持不变。优先级是利用某一范围内的一个整数来表示的,例如0255中的某一整数,又把该整数称为优先数。确定进程优先级大小的依据有如下三个:(1)进程类型。(2)进程对资源的需求。(3)用户要求。第35页/共126页2)动态优先级动态优先级是指在创建进程之初,先赋予其一个优先级,然后其值随进程的推进或等待时间的增加而改变,以便获得更好的调度性能。第36页/共126页3.3.4 3.3.4 多队列调度算法多队列调度算法如前所述的各种调度算法,尤其在应用于进程调度时,由于系统中仅设置一个进程的就绪队列,即低级调度算法是固定的、单一的,无法满足系统中不同用户对进程调度策略的不同要求,在多处
20、理机系统中,这种单一调度策略实现机制的缺点更显突出,由此,多级队列调度算法能够在一定程度上弥补这一缺点。第37页/共126页3.3.5 3.3.5 多级反馈队列多级反馈队列(multileved feedback queue)(multileved feedback queue)调度算法调度算法 1.1.调度机制调度机制多级反馈队列调度算法的调度机制可描述如下:(1)设置多个就绪队列。图3-4是多级反馈队列算法的示意图。第38页/共126页图3-4 多级反馈队列调度算法第39页/共126页(2)每个队列都采用FCFS算法。当新进程进入内存后,首先将它放入第一队列的末尾,按FCFS原则等待调度。
21、当轮到该进程执行时,如它能在该时间片内完成,便可撤离系统。否则,即它在一个时间片结束时尚未完成,调度程序将其转入第二队列的末尾等待调度;如果它在第二队列中运行一个时间片后仍未完成,再依次将它放入第三队列,依此类推。当进程最后被降到第n队列后,在第n队列中便采取按RR方式运行。第40页/共126页(3)按队列优先级调度。调度程序首先调度最高优先级队列中的诸进程运行,仅当第一队列空闲时才调度第二队列中的进程运行;换言之,仅当第1(i-1)所有队列均空时,才会调度第i队列中的进程运行。如果处理机正在第i队列中为某进程服务时又有新进程进入任一优先级较高的队列,此时须立即把正在运行的进程放回到第i队列的
22、末尾,而把处理机分配给新到的高优先级进程。第41页/共126页2.2.调度算法的性能调度算法的性能在多级反馈队列调度算法中,如果规定第一个队列的时间片略大于多数人机交互所需之处理时间时,便能较好地满足各种类型用户的需要。(1)终端型用户。(2)短批处理作业用户。(3)长批处理作业用户。第42页/共126页3.3.6 3.3.6 基于公平原则的调度算法基于公平原则的调度算法 1.1.保证调度算法保证调度算法保证调度算法是另外一种类型的调度算法,它向用户所做出的保证并不是优先运行,而是明确的性能保证,该算法可以做到调度的公平性。一种比较容易实现的性能保证是处理机分配的公平性。如果在系统中有n个相同
23、类型的进程同时运行,为公平起见,须保证每个进程都获得相同的处理机时间1/n。第43页/共126页在实施公平调度算法时系统中必须具有这样一些功能:(1)跟踪计算每个进程自创建以来已经执行的处理时间。(2)计算每个进程应获得的处理机时间,即自创建以来的时间除以n。(3)计算进程获得处理机时间的比率,即进程实际执行的处理时间和应获得的处理机时间之比。(4)比较各进程获得处理机时间的比率。如进程A的比率最低,为0.5,而进程B的比率为0.8,进程C的比率为1.2等。(5)调度程序应选择比率最小的进程将处理机分配给它,并让该进程一直运行,直到超过最接近它的进程比率为止。第44页/共126页2.2.公平分
24、享调度算法公平分享调度算法分配给每个进程相同的处理机时间,显然,这对诸进程而言,是体现了一定程度的公平,但如果各个用户所拥有的进程数不同,就会发生对用户的不公平问题。第45页/共126页3.4 3.4 实实 时时 调调 度度在实时系统中,可能存在着两类不同性质的实时任务,即HRT任务和SRT任务,它们都联系着一个截止时间。为保证系统能正常工作,实时调度必须能满足实时任务对截止时间的要求。为此,实现实时调度应具备一定的条件。第46页/共126页3.4.1 3.4.1 实现实时调度的基本条件实现实时调度的基本条件1.1.提供必要的信息提供必要的信息为了实现实时调度,系统应向调度程序提供有关任务的信
25、息:(1)就绪时间,是指某任务成为就绪状态的起始时间,在周期任务的情况下,它是事先预知的一串时间序列。(2)开始截止时间和完成截止时间,对于典型的实时应用,只须知道开始截止时间,或者完成截止时间。第47页/共126页(3)处理时间,一个任务从开始执行,直至完成时所需的时间。(4)资源要求,任务执行时所需的一组资源。(5)优先级,如果某任务的开始截止时间错过,势必引起故障,则应为该任务赋予“绝对”优先级;如果其开始截止时间的错过,对任务的继续运行无重大影响,则可为其赋予“相对”优先级,供调度程序参考。第48页/共126页2.2.系统处理能力强系统处理能力强在实时系统中,若处理机的处理能力不够强,
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 第三 汤小丹 计算机 操作系统 官方 课件 第四
限制150内