第三章 处理机调度与死锁.ppt
《第三章 处理机调度与死锁.ppt》由会员分享,可在线阅读,更多相关《第三章 处理机调度与死锁.ppt(104页珍藏版)》请在三一办公上搜索。
1、第三章处理机调度与死锁,第三章 处理机调度与死锁,3.1 处理机调度的基本概念 3.2 调度算法 3.3 实时调度 3.4 产生死锁的原因和必要条件 3.5 预防死锁的方法 3.6 死锁的检测与解除,3.1 处理机调度的基本概念,3.1 高、中、低三级调度 1、高级调度(作业调度、长程调度、接纳调度)将外存作业调入内存,创建PCB等,插入就绪队列。一般用于批处理系统,分/实时系统一般直接入内存,无此环节。,3.1 处理机调度的基本概念,3.1 高、中、低三级调度 1、高级调度(作业调度、长程调度、接纳调度)在每次执行作业调度时,都须做出以下两个决定。1)接纳多少个作业 2)接纳哪些作业,3.1
2、 处理机调度的基本概念,3.1高、中、低三级调度 1、高级调度(作业调度、长程调度、接纳调度)调度特性1.接纳作业数(内存驻留数)太多周转时间T长太少系统效率低2.接纳策略:即采用何种调度算法:FCFS、短作业优先等,2.低级调度(Low Level Scheduling),1)非抢占方式(Non-preemptive Mode)可能引起进程调度的因素可归结为这样几个:正在执行的进程执行完毕,或因发生某事件而不能再继续执行;执行中的进程因提出I/O请求而暂停执行;在进程通信或同步过程中执行了某种原语操作,如P操作(wait操作)、Block原语、Wakeup原语等。,处理机调度的基本概念(2)
3、,2.低级调度(Low Level Scheduling),1)非抢占方式(Non-preemptive Mode)这种调度方式的优点是实现简单、系统开销小,适用于大多数的批处理系统环境。但它难以满足紧急任务的要求立即执行,因而可能造成难以预料的后果。显然,在要求比较严格的实时系统中,不宜采用这种调度方式。,处理机调度的基本概念(2),处理机调度的基本概念(2),2、低级调度(进程调度,短程调度)主要是由分派程序(Dispatcher)分派处理机。2.抢占方式(1)时间片原则(2)优先权原则(3)短作业优先原则。,处理机调度的基本概念(2),3、中级调度(中程调度)为提高系统吞吐量和内存利用率
4、而引入的一内-外存对换功能(换出时,进程为挂起或就绪驻外状态)运行频率:低中高。,3.1.2调度的队列模型,一、仅有进程调度的队列模型,就绪队列,CPU,阻塞队列,交互用户,时间片完,进程调度,进程完成,等待事件,事件出现,图 3-1 仅具有进程调度的调度队列模型,3.1.2调度的队列模型,二、具有高/低级模型,就绪队列,CPU,阻塞队列,时间片完,进程调度,进程完成,等待事件1,事件1出现,后备队列,阻塞队列,等待事件2,事件2出现,作业调度,图 3-2 具有高、低两级调度的调度队列模型,(1)就绪队列的形式。(2)设置多个阻塞队列。,图 3-2 示出了具有高、低两级调度的调度队列模型。该模
5、型与上一模型的主要区别在于如下两个方面。,三.同时具有三级调度的调度队列模型,图 3-3 具有三级调度时的调度队列模型,3.1.3 选择调度方式和算法的若干准则,一、面向用户的准则1周转时间短(常用于批处理系统)概念:作业从提交 完成的时间.分为:(1)驻外等待调度时间(2)驻内等待调度时间(3)执行时间(4)阻塞时间,一、面向用户的准则1周转时间短平均周转时间:平均带权周转时间:Ts为实际服务时间,作业的周转时间Ti。可见带权w越小越好。,3.1.3选择调度方式和算法的若干准则,一、面向用户的准则2响应时间快:(对交互性作业)概念:键盘提交请求到首次响应时间(1)输入传送时间(2)处理时间(
6、3)响应传送时间3截止时间的保证(特别于实时系统)4优先权准则:(即需要抢占调度),3.1.3选择调度方式和算法的若干准则,二、面向系统的准则1吞吐量高(特别于批处理):单位时间完成作业数2处理机利用率好:(因CPU贵,特别于大中型多用户系统)3各类资源的平衡利用。,3.1.3选择调度方式和算法的若干准则,3.2调度算法是一个资源分配问题,3.2.1先来先服务和短作业(进程)优先调度算法 1.FCFS特点:简单,有利于长作业,即CPU繁忙性作业可以分别用于作业调度和进程调度,先来先服务调度算法例,先来先服务调度算法例,2.短作业(进程)优先调度算法,短作业(进程)优先调度算法SJ(P)F,是指
7、对短作业或短进程优先调度的算法。它们可以分别用于作业调度和进程调度。,3.2 调度算法,2.短作业(进程)优先调度算法,短作业优先(SJF)的调度算法,是从后备队列中选择一个或若干个估计运行时间最短的作业,将它们调入内存运行。而短进程优先(SPF)调度算法,则是从就绪队列中选出一估计运行时间最短的进程,将处理机分配给它,使它立即执行并一直执行到完成,或发生某事件而被阻塞放弃处理机时,再重新调度。,3.2 调度算法,图3.4 FCFS和SJF比较,图3.4 FCFS和SJF比较,3.2调度算法是一个资源分配问题,2.短作业进程优先调度算法:SJ(P)F提高了平均周转时间和平均带权周转时间(从而提
8、高了系统吞吐量)特点:对长作业不利,有可能得不到服务(饥饿)估计时间不易确定该算法完全未考虑作业的紧迫程度,因而不能保证紧迫性作业(进程)会被及时处理。,3.2.2 高优先权优先调度算法,1.优先权调度算法类型非抢占式优先权算法:在这种方式下,系统一旦把处理机分配给就绪队列中优先权最高的进程后,该进程便一直执行下去,直至完成;或因发生某事件使该进程放弃处理机时,系统方可再将处理机重新分配给另一优先权最高的进程。主要用于批处理系统中;也可用于某些对实时性要求不严的实时系统中。,3.2.2 高优先权优先调度算法,1.优先权调度算法类型 抢占式优先权算法系统同样是把处理机分配给优先权最高的进程,使之
9、执行。当出现了另一个其优先权更高的进程,会发生抢占实时性更好。常用于要求比较严格的实时系统中,以及对性能要求较高的批处理和分时系统中。,3.2.2 高优先权优先调度算法,2.优先权类型:1)静态优先权:进程优先权(一般地,利用某一范围内的一个整数来表示)在整个运行期不变。确定优先权依据(1)进程类型(2)进程对资源的需求;(3)根据用户需求。特点:简单,但低优先权作业可能长期不被调度。,3.2.2高优先权优先调度算法,2.优先权类型:2)动态优先权:如:优先权随执行时间而下降,随等待时间而升高。响应比 Rp=(等待时间服务时间)/服务时间 响应比作为优先权。优点:长短兼顾 缺点:需计算Rp,3
10、.高响应比优先调度算法Highest Response Ratio Next(HRRN),优先权的变化规律可描述为:,由于等待时间与服务时间之和,就是系统对该作业的响应时间,故该优先权又相当于响应比RP。据此,又可表示为:,3.2.2高优先权优先调度算法,(1)如果作业的等待时间相同,则要求服务的时间愈短,其优先权愈高,因而该算法有利于短作业。(2)当要求服务的时间相同时,作业的优先权决定于其等待时间,等待时间愈长,其优先权愈高,因而它实现的是先来先服务。,3.2.2高优先权优先调度算法,(3)对于长作业,作业的优先级可以随等待时间的增加而提高,当其等待时间足够长时,其优先级便可升到很高,从而
11、也可获得处理机。,3.2.2高优先权优先调度算法,高响应比优先调度算法(HRRN),高响应比优先调度算法(HRRN),3.2.3 基于时间片的轮转调度算法,1.时间片轮转法(Round Robin,RR)在早期的时间片轮转法中,系统将所有的就绪进程按先来先服务的原则,排成一个队列,每次调度时,把CPU分配给队首进程,并令其执行一个时间片。时间片的大小从几ms到几百ms。计时器发出时钟中断请求,3.2.3基于时间片的轮转调度算法,1.时间片轮转时间片大小的确定太大:退化为FCFS;太小:系统开销过大系统对响应时间的要求;T=nq(q时间片,n进程个数)就绪队列中进程的数目;系统的处理能力:(应保
12、证一个时间片处理完常用命令),基于时间片的轮转调度算法,基于时间片的轮转调度算法,进程,基于时间片的轮转调度算法,2.多级反馈队列调度算法,(1)应设置多个就绪队列,并为各个队列赋予不同的优先级。第一个队列的优先级最高,第二个队列次之,其余各队列的优先权逐个降低。该算法赋予各个队列中进程执行时间片的大小也各不相同,在优先权愈高的队列中,为每个进程所规定的执行时间片就愈小。例如,第二个队列的时间片要比第一个队列的时间片长一倍,第i+1个队列的时间片要比第i个队列的时间片长一倍。图 3-5 是多级反馈队列算法的示意。,图 3-5 多级反馈队列调度算法,(2)当一个新进程进入内存后,首先将它放入第一
13、队列的末尾,按FCFS原则排队等待调度。当轮到该进程执行时,如它能在该时间片内完成,便可准备撤离系统;如果它在一个时间片结束时尚未完成,调度程序便将该进程转入第二队列的末尾,再同样地按FCFS原则等待调度执行;如果它在第二队列中运行一个时间片后仍未完成,再依次将它放入第三队列,如此下去,当一个长作业(进程)从第一队列依次降到第n队列后,在第n队列中便采取按时间片轮转的方式运行。,2.多级反馈队列调度算法,(3)仅当第一队列空闲时,调度程序才调度第二队列中的进程运行;仅当第1(i-1)队列均空时,才会调度第i队列中的进程运行。如果处理机正在第i队列中为某进程服务时,又有新进程进入优先权较高的队列
14、(第1(i-1)中的任何一个队列),则此时新进程将抢占正在运行进程的处理机,即由调度程序把正在运行的进程放回到第i队列的末尾,把处理机分配给新到的高优先权进程。,3.2.3多级反馈队列调度算法,2.多级反馈队列调度特点:长、短作业兼顾,有较好的响应时间(1)短作业一次完成;(2)中型作业周转时间不长;(3)大型作业不会长期不处理。,3.多级反馈队列调度算法的性能,终端型作业用户。(2)短批处理作业用户。(3)长批处理作业用户。,3.3.1 实现实时调度的基本条件1提供必要的调度信息(1)就绪时间;(2)开始/完成截止时间;(3)处理时间;(4)资源要求;(5)优先级;,3.3实时调度,3.3.
15、1 实现实时调度的基本条件,2.系统处理能力强 在实时系统中,通常都有着多个实时任务。若处理机的处理能力不够强,则有可能因处理机忙不过来而使某些实时任务不能得到及时处理,从而导致发生难以预料的后果。假定系统中有m个周期性的硬实时任务,它们的处理时间可表示为Ci,周期时间表示为Pi,则在单处理机情况下,必须满足下面的限制条件:系统才是可调度的。,3.3实时调度,假如系统中有6个硬实时任务,它们的周期时间都是 50 ms,而每次的处理时间为 10 ms,则不难算出,此时是不能满足上式的,因而系统是不可调度的。,解决的方法是提高系统的处理能力,其途径有二:其一仍是采用单处理机系统,但须增强其处理能力
16、,以显著地减少对每一个任务的处理时间;其二是采用多处理机系统。假定系统中的处理机数为N,则应将上述的限制条件改为:,3.3.1实现实时调度的基本条件3.采用抢占调度方式剥夺方式:一般都采用此非剥夺方式(实现简单):一般应使所有的实时任务较小,以及时放弃CPU。4.具有快速切换机制具有快速响应外部中断能力。快速任务分派,3.3实时调度,3.3.2实时调度算法的分类,1 非抢占式调度算法时间片轮转 秒级非抢占优先权(协同)秒毫秒级2 抢占式调度算法时钟中断抢占优先权 毫秒级基于抢占点抢占立即抢占immediate preemption 毫秒微秒级只要不在临界区即抢占(中断引发),图 3-6 实时进
17、程调度,3.3实时调度,3.3.3 常用的几种实时调度算法,1.最早截止时间优先EDF(earliest deadline first)算法根据任务的开始截止时间来确定任务的优先级截止时间越早,优先级越高可以是抢占式或非抢占式,3.3.3 常用的几种实时调度算法,1.最早截止时间优先即EDF(Earliest Deadline First)算法,图 3-7 EDF算法用于非抢占调度方式,2.最低松弛度优先LLF算法,松弛度:任务紧急(或松弛)的程度。若A进程需在200ms时完成,其本身运行需要100ms,当前时刻是10ms,则A的松弛度为:2001001090任务的紧急程度愈高,为该任务所赋予
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 第三章 处理机调度与死锁 第三 处理机 调度 死锁

链接地址:https://www.31ppt.com/p-2242125.html