热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

多级队列调度算法可视化界面_操作系统的调度

调度的定义CPU并不只是简单的根据FIFO的规则来实现进程线程的调度;如何结合考虑进程线程的优先级、运行时间等多方面的因素,实现合理、科学、高效得调度是
371cf5bcea5dba50b9c0d7707d8a2bf8.png

调度的定义

CPU并不只是简单的根据FIFO的规则来实现进程/线程的调度;
如何结合考虑进程/线程的优先级运行时间等多方面的因素,实现合理、科学、高效得调度是本文要研究的核心内容;
758ca3458c7b38bbbe5876200b95292f.png

如上图中,左侧是FIFO+优先级的综合调度,右侧是FIFO+运行时间的综合调度;

而所谓调度,就是从就绪队列中按照一定的算法选择一个进程/线程并将CPU等资源分配给它运行,已达到并发的效果;

调度的三个层次

高级调度:磁盘 -> 内存(只会调度一次,创建进程的过程)

磁盘上的程序软件可以有千千万万个(够大),但是内存相对磁盘而言,是相当有限的,一般内存就8G,没法同时存放磁盘上所有的软件,因此一般只会启动磁盘的一部分软件,即创建相应的进程,存储并运行在内存上;

06a6bfd728581d68f399bdbef3896c5e.png
磁盘上的作业提交后,等待被创建成新的进程(即,高级调度)

磁盘上的某个软件程序以作业形式提交后,操作系统并不会立即就将其创建成新进程,作业的提交需要先进入磁盘中的作业等待队列中,CPU对这个等待队列中的作业以某种算法(通常思路是综合FIFO+优先级+***考虑因素)进行调度;所以我们平常使用Windows点击某个.exe软件时,界面上可能不会立马打开的软件窗口,可能需要等待一会软件才“启动响应”,这个过程其实就是新提交的创建进程的作业只是被放入等待队列中,还没有被CPU从队列中调度出来并执行作业;

这样的通过将作业提交至磁盘上的等待队列中,等待CPU调度并创建进程,然后将磁盘上的软件存储在内存的虚拟地址空间上,并由CPU取指执行的过程即是本小节讨论的“高级调度”;

e7be23af0b04ad310c0c633cbda942b5.png
高级调度:提交磁盘程序作业,等待创建新进程

中级调度:磁盘->内存(会被调度多次,处于挂起态的进程重新调入内存的过程)

由于内存是稀缺资源,对于当前未处于运行态的某些进程,不能“占着茅坑不拉屎”,当前未处于运行态的进程被临时从内存置换到磁盘中,等待该进程再次具备运行条件或者内存有足够余量时,再重新调回内存;这样做能极大提升内存利用率系统吞吐量;

这里的暂时将进程调到磁盘等待的进程状态,被称为挂起状态

(注:从这段话,我们可以稍作思考,进程的PCB和进程在内存中的虚拟地址空间,在逻辑上应该是设计成分开存放的,这样即便当进程的代码段、数据段等被置换到磁盘上,该进程的PCB并不会被置换出去,PCB仍旧在常驻内存中,虽然在内存中具体存放位置,我还不太清楚,但PCB应该还在就绪队列或者阻塞队列指向的某个内存地址上,这样的话,操作系统才可以继续对该进程进行管理,仍不会影响该进程在未来的某个时候可能会被分配CPU时间片,并重新获得CPU使用权)

2b25a3a4b82fbaaa974fa2211e225bd0.png

注意这张图,虽然有两个进程从内存中被换到了磁盘中,但是与其对应的两个PCB依旧放在常驻内存上,接受操作系统的管理与调度;

上面介绍了什么是挂起态:因内存有限,当前不在运行的进程被暂时调到外存,此时进程的状态就是挂起态,即没在运行、又没有就绪或阻塞,更不是创建或终止;

而根据进程挂起之前的状态进行细分,可分为:就绪挂起阻塞挂起;

不管是就绪挂起,还是阻塞挂起,都得是从磁盘重新调度到内存上,才能重新被运行;

1c5cd877f45a7f7c2dfb8d6af734c30b.png
五状态模型(未引入挂起态)
ef06971da7c7d3f692dfacc35132bbe8.png
341c2f2f4f0da2e7c0eae79073fe11ca.png
七状态模型

在七状态模型中,需要尤为注意的有:

  • 存储在外存的阻塞挂起进程可以因时间的响应,直接在外存中转换成就绪挂起,因为都是挂起,所以进程依然是在外存上;
  • 当进程刚用完时间片,可以直接从运行态,变成就绪挂起态;
  • 当新的进程刚完成创建过程,可能也会直接进入就绪挂起;

而发生这一切的原因,基本都是因为内存不够用了

低级调度:即进程调度,从就绪队列中取出进程,将其转换成运行态(调度频率最高)

低级调度就是我们最常关注的多进程的管理与切换,即选择合适的算法从就绪队列中选取一个进程,并为其分配CPU等资源;

0ffdf94c50a2339c444734433390b1ad.png

三个层次的调度对比:

afddabf1343ad3677d39f2383ea5c7bc.png

操作系统调度总结

096bf25c6f458f5488a18e4c413644c3.png



推荐阅读
  • 浪潮AI服务器NF5488A5在MLPerf基准测试中刷新多项纪录
    近日,国际权威AI基准测试平台MLPerf发布了最新的推理测试结果,浪潮AI服务器NF5488A5在此次测试中创造了18项性能纪录,显著提升了数据中心AI推理性能。 ... [详细]
  • 本文提供了一套实用的方法论,旨在帮助开发者构建能够应对高并发请求且易于扩展的Web服务。内容涵盖了服务器架构、数据库管理、缓存策略以及异步处理等多个方面。 ... [详细]
  • 一面问题:MySQLRedisKafka线程算法mysql知道哪些存储引擎,它们的区别mysql索引在什么情况下会失效mysql在项目中的优化场景&# ... [详细]
  • 深入理解Kafka架构
    本文将详细介绍Kafka的内部工作机制,包括其工作流程、文件存储机制、生产者与消费者的具体实现,以及如何通过高效读写技术和Zookeeper支持来确保系统的高性能和稳定性。 ... [详细]
  • Java性能优化指南 | 制定有效的性能优化策略
    探讨Java应用性能优化的方法与策略,包括性能测试技巧、常见问题及解决方案,旨在帮助开发者提升系统性能。 ... [详细]
  • 新萝卜Ghost Xp Sp3 装机版
    新萝卜GhostXpSp3装机版XLB_201305ZJB.iso大小:901457920字节MD5:EBE33B7DB119CF2D0B1D79F8F0FC22BFSHA1:0 ... [详细]
  • 在学习过程中遇到了一个问题,书本上关于使用贪心算法实现哈夫曼编码的部分代码不完整,希望有同学能够帮助完善。 ... [详细]
  • 本文探讨了在支付项目开发中使用SS5 Socket Server实现内部网络访问外部网络的技术方案。详细介绍了SS5的安装、配置及性能测试过程,旨在为面临相同需求的技术人员提供参考。 ... [详细]
  • Java面向对象编程深入解析
    本文详细探讨了Java中的关键字static、单例模式、main()方法、代码块、final关键字、抽象类与方法、模板方法设计模式、接口、内部类等内容,旨在帮助读者深入理解和掌握Java面向对象编程的核心概念。 ... [详细]
  • 在Ubuntu 16.04中使用Anaconda安装TensorFlow
    本文详细介绍了如何在Ubuntu 16.04系统上通过Anaconda环境管理工具安装TensorFlow。首先,需要下载并安装Anaconda,然后配置环境变量以确保系统能够识别Anaconda命令。接着,创建一个特定的Python环境用于安装TensorFlow,并通过指定的镜像源加速安装过程。最后,通过一个简单的线性回归示例验证TensorFlow的安装是否成功。 ... [详细]
  • 本文详细介绍了WebRTC提供的音频处理引擎,包括自动增益控制(AGC)、噪声抑制(ANS)、移动设备声学回声消除(AEC)及静音检测(VAD)等核心算法,并提供了完整的C语言实现代码。 ... [详细]
  • 近期尝试重构 GDI 并自定义图像处理函数时,发现自定义函数的图像复制性能显著低于 Windows 原生 GDI 函数。通过研究了解到,系统可能利用了 GPU 加速来提升这些函数的效率。 ... [详细]
  • 本文介绍了数字音视频编解码技术标准,特别是中国自主研发的AVS标准,及其在短视频软件开发中的应用。文章探讨了AVS标准的发展历程、技术特点以及与国际标准的对比。 ... [详细]
  • 本文探讨了Java虚拟机(JVM)的功能,解释了为何源代码需先编译为字节码(.class),并详细介绍了Java开发工具包(JDK)和Java运行时环境(JRE)的区别及其各自的角色。此外,还将介绍如何将Java文件打包成可执行的.jar文件,并解析程序如何从硬盘加载到内存以供CPU执行。 ... [详细]
  • 解决MySQL错误2002:无法建立数据库连接
    本文详细描述了在Digital Ocean服务器上托管的多个WordPress站点突然出现数据库连接错误的情况,并提供了有效的解决方案。 ... [详细]
author-avatar
笃志单车小博_801
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有