操作系统知识点(五)——CPU调度

CPU调度

背景

  • CPU调度

    • 从就绪队列中挑选一个进程/线程作为CPU将要运行的下一个进程/线程
    • 调度程序:挑选进程/线程的内核函数
    • 什么时候进行调度
  • 调度时机

    • 进程从运行状态切换到等待状态
    • 进程被终结了
  • 非抢占系统:调度程序必须等待事件结束,当前进程主动放弃CPU时

  • 可抢占系统

    • 中断请求被服务例程响应完成时
    • 当前进程被抢占:进程时间片用完;进程从等待切换到就绪

调度准则

  • CPU使用率:CPU处于忙状态的时间百分比
  • 吞吐量:单位时间内完成的进程数量
  • 周转时间:进程从初始化到结束的总时间
  • 等待时间:进程在就绪队列中的总时间
  • 响应时间:从提交请求到产生响应所花费的总时间

调度算法

  • 先来先服务(First Come First Served,FCFS):依据进程进入就绪状态的先后顺序排列
    • 优点:简单
    • 缺点
      • 平均等待时间波动较大,短进程可能排在长进程后面
      • I/O资源和CPU资源的利用率较低
  • 短进程优先算法(SPN,SJF,SRT):选择就绪队列中执行时间最短进程占用CPU进入运行状态
    • 短剩余时间优先算法(SRT):可抢占,SPN算法的可抢占改进
    • 缺点
      • 可能导致饥饿,连续的短任务流会使长进程无法获得CPU资源
      • 需要预知未来,如何预估下一个CPU计算的持续时间:询问用户,如果用户欺骗就杀死相应进程
  • 最高响应比优先算法(Highest Response Ratio Next,HRRN):选择就绪队列中响应比R值最高的进程,R=(w+s)/s,w:等待时间;s:执行时间
    • 在SPN调度的基础上改进
    • 不可抢占
    • 关注进程的等待时间
    • 防止无限期推迟
  • 时间片轮转算法(Round Robin,RR):时间片结束时,按FCFS算法切换到下一个就绪进程
    • 算法开销,额外上下文切换
    • 时间片太长,等待时间过长,极限情况退化成FCFS
    • 时间片太小,反应迅速,但产生大量上下文切换
    • 时间片选择目标,维持上下文切换开销处于1%以内
  • 多级反馈队列算法(MultiLevel Feedback Queues,MLFQ)
    • 就绪队列被划分成独立的队列
    • 每个队列拥有自己的调度策略
    • 调度必须在队列间进行:固定优先级、时间切片
    • 进程可在不同队列间移动的多级列算法
      • 时间片大小随优先级别增加而增加
      • CPU密集型进程的优先级下降很快
      • 如进程在当前的时间片没有完成,则降到下一个优先级
      • I/O密集型进程停留在高优先级
  • 公平共享调度算法(Fair Share Scheduling,FSS)
    • 一些用户组比其它用户组更重要
    • 保证不重要的组无法垄断资源
    • 未使用的资源按比例分配
    • 没有达到资源使用率目标的组获得更高的优先级

实时调度

  • 实时操作系统:正确性依赖于其实际和功能两方面的操作系统

  • 性能指标

    • 时间约束的及时性
    • 速度和平均性能相对不重要
  • 特性

    • 时间约束的可预测性
  • 强实时操作系统:要求在指定的时间内必须完成重要任务

  • 弱实时操作系统:重要进程有高优先级,要求尽量但非必须完成

  • 速率单调调度算法(RM,Rate Monntonic)

    • 通过周期安排优先级
    • 周期越短优先级越高
    • 执行周期最短的任务
  • 最早截止时间优先算法(EDF,Earliest Deadline First)

    • 截止时间越早优先级越高
    • 执行截止时间最早的任务

多处理器调度

  • 多处理机调度的特征

    • 多个处理机组成一个多处理机系统
    • 处理机间可负载共享
  • 对称多处理器(SMP,Symmetric multiprocessing)调度

    • 每个处理器运行自己的调度程序
    • 调度程序对共享资源的访问需要进行同步
  • 静态进程分配

    • 进程从开始到结束都被分配到一个固定的处理机上执行
    • 每个处理机有自己的就绪队列
    • 调度开销小
    • 各处理机可能忙闲不均
  • 动态进程分配

    • 进程在执行中可分配到任意空闲处理机执行
    • 所有处理机共享一个公共的就绪队列
    • 调度开销大
    • 各处理机的负载是均衡的

优先级反转

  • 操作系统中出现高优先级进程长时间等待低优先级进程所占用资源的现象

  • 基于优先级的可抢占调度算法存在优先级反置

  • 优先级继承:占用资源的低优先级进程继承申请资源的高优先级进程的优先级

    • 只在占有资源的低优先级进程被阻塞时,才提高占用资源进程的优先级
  • 优先级天花板协议:占用资源进程的优先级和所有可能申请该资源的进程的最高优先级相同

    • 不管是否发生等待,都提升占用资源进程的优先级
    • 优先级高于系统中所有被锁定的资源的优先级上限,任务执行临界区时不会被阻塞

更多精彩,关注“咋家”

?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352

推荐阅读更多精彩内容