百科问答小站 logo
百科问答小站 font logo



Linux 为什么不是实时操作系统? 第1页

  

user avatar   bei-ji-85 网友的相关建议: 
      

调度器的实时性不等于操作系统的实时性。

举个最简单的例子:

实时性的调度时间是确定的,但如果某任务调度过程中,发生了缺页中断,那么此时需要从磁盘上读取数据,这个过程就是完全不确定的,也不是实时的。所以实时系统里是不能有虚拟内存的,在这方面Linux的软实时设计就完全不适用。

实时系统=实时调度模型+整个操作系统的实时设计(主要是驱动)。

具体表现为:网络、文件系统、设备驱动的设计都是实时的。一个高优先级的任务发起的文件系统请求、网络请求,就应该优先调度,而不是使用缓存等方式排队调度。

设计一个实时调度器非常容易(算法其实不复杂),但要把整个系统里的所有驱动都改成实时的,这样的工作量就非常巨大了,Linux也不可能这么做,这么做的代价很高,并且严重影响系统效率。与很多人的理解相反:实时系统不是一个“快速系统”,由于实时系统的调度特性,实际上实时系统比Linux这种桌面系统的性能要差。

当然了,软实时和硬实时的使用场景不一样,如果应用场景对实时性要求不是那么的严格,软实时也是可以的。


补充一些破坏实时性的设计:

虚拟内存(页面文件):加载时间不确定,延迟太大;
线程池:当请求的任务数量大于线程池的数量时,优先级调度就可能会被破坏;
文件系统缓存:主要是延迟写入、延迟关闭这些,都会破坏实时性原则;
网络报文队列:除非这个队列支持插队的设计,否则就不是一个实时的网络。




  

相关话题

  大家是怎么念 null 的? 
  Unicode 和 UTF-8 有什么区别? 
  为什么操作系统没有前端和后端,而计算机很多其他领域却分前后端? 
  许多人认为「学计算机吃青春饭」,为什么还那么多人学呢? 
  解压文件的速度瓶颈在cpu还是硬盘速度? 
  Linux和Windows可以安装在任何个人电脑上,而安卓却需要为每台设备定制一个版本的原因是什么? 
  一百行以下有哪些给力代码? 
  如何解决图神经网络(GNN)训练中过度平滑的问题? 
  Linux设备驱动开发 新手,创建第一个字符设备驱动时对一些代码的功能不是很了解,能解释一下吗? 
  如何评价上海交大计算机系的保研事故? 

前一个讨论
x86架构字节序是小端模式,其bit位序是类似小端模式还是大端模式?
下一个讨论
嵌入式设备使用NandFlash作为存储,那么不使用文件系统是否可行?





© 2024-11-24 - tinynew.org. All Rights Reserved.
© 2024-11-24 - tinynew.org. 保留所有权利