操作系统和普通的大型应用程序项目类似,都涉及代码组织方式的问题,但操作系统的独特之处在于其核心部分必须运行在内核态,kernel model,所谓内核态严格讲是指在该状态下程序拥有对硬件(hardware)的所有控制权,运行在用户态的程序做不到这一点。
有的同学可能会有疑问,操作系统(或者说内核)不都是核心部分吗?严格来讲像进程管理调度、内存管理等就是核心部分,但像驱动等就不是那么核心了,那么这一部分也需要放在内核态吗?
围绕这一划分,出现了两种操作系统的设计方式,关于这两种设计方法的争论就和复杂指令集(cisc)与精简指令集(risc)哪个更好一样至今 没有非常明确的定论 。
大一统,全部运行在内核态最简单的划分就是没有划分 ,我们可以把所有内核代码放在内核态,内核中的任何代码都拥有控制硬件的全部特权,显然这种设计方法非常简单,因为操作系统设计者不用费心去想哪一部分该放在内核态。
由于全部内核程序都运行在内核态,编译好的内核程序就是一个单独的二进制可执行文件,这时的操作系统运行起来后就是一个大进程,所有内核代码运行在一个单独的地址空间中,这和我们实现的稍微复杂的单进程应用程序类似,这种大一统的设计就是所谓的宏内核,monolithic kernel,个人认为叫“一体化内核”更形象些。
这种组织方式和tcp/ip协议栈的分层实现有点类似。
现在内核代码已经组织好了,毕竟内核是为上层应用提供服务的,那么上层应用该怎样调用内核代码呢?这就是系统调用的作用,system call。
上层应用程序通过系统调用与内核进行交互。
由于内核代码唯一同一个地址空间中,因此内核中各部分的交互极为简单,就是普通的函数调用,文件系统中的某块cache可以非常容易的被虚拟内存系统共享使用。
但宏内核也是有缺点的,由于内核代码位于同一个地址空间,代码趋于复杂化,复杂就容易出错,但内核和普通程序不同,一旦内核中某一模块出现bug将导致整个内核崩溃,底层的内核崩溃后上层的应用程序就无法继续正常推进。
当然也有人不在乎在这一点,linus认为内核中有bug正常, 有bug就找到它、修复它而不是用某种机制试图忽略它 ,没错,c++中的异常就是试图忽略bug的机制,这就是为什么很多公司的规范中禁止使用异常的原因。
总之,内核崩溃后就必须重启计算机。
保留核心,非必要不留在内核为减少内核崩溃的风险,一个简单的办法就是让内核尽量精简,只保留核心部分运行在内核态,其它代码以用户态进程的形式运行,就像这样:
运行在用户态的操作系统程序被称为server,像负责文件操作的file server等,此时用户进程想要使用操作系统提供的服务的话就必须借助进程间通信,inter-process communication,即ipc,借助内核,消息从一个进程发送到另一个进程然后等待返回。
这样,内核只需要对上层应用提供一些简单的接口即可,像创建进程、发送消息等,这种实现方式可以让内核尽可能简单,因为大部分内核程序都运行在用户态,且运行在不同的地址空间中,此时设备驱动中的bug不会影响到内核,这种操作系统的实现方式就被称为微内核, micro kernel。
就像宏内核那样,微内核也有自己的缺点,那就是性能。由于宏内核的代码都在同一个地址空间中,因此模块间的交互可以非常简单,简单的函数调用即可,但模块间交互对微内核来说则可能涉及进程间通信,看上图,如果某个应用程序需要请求使用file server,这条链路涉及到:
请求:应用程序 -> 内核 -> file server返回:filer server -> 内核 -> 应用程序每一个->都涉及上下文切换,而这对宏内核来说则简单很多。
现实中是什么样子?现实的操作系统中两种实现方式都很常见,linux以及许多unix就是典型的宏内核,而mac os x 以及 windows nt则一般认为是微内核,华为的鸿蒙harmony os则宣传是微内核。
有趣的是,对linus创建linux影响极大的minix操作系统也是微内核,而linux则是宏内核,难怪minix的作者——也是操作系统这门课的教授说过,如果linus是他的学生的话那么操作系统系统这门课的期末考试linus可能很难通过,哈哈,因为minx的作者认为在linux被创造出来的上世纪90年代竟然还有人以宏内核的方式来编写操作系统,这简直不可思议,而linus则不以为意,并进行了火爆的回击,关于这一段的八卦后续有机会和大家聊聊,非常有趣。
可以看到操作系统的设计方式就和cpu关于复杂指令集与精简指令集的设计一样分成了两派, 关于宏内核与微内核孰优孰劣争论至今依然没有定论 。
新版tplink路由器修改密码的方法
UART整体的仿真方法和testbench结构讲解
FM2822型可调光电子镇流器控制器及其应用
现代计算机的基石——英特尔8086处理器
盘点未来物联网新能源——纸基电池
什么是宏内核、微内核?
香薰机如何实现缺液提醒
降压恒流芯片的工作原理及优点
为什么需要基于服务器的局域网?
RS-485收发器相关问题已经困扰您许久?
过孔——PCB设计信号失真的原因,不容小觑
比特币对于人们的日常用处是什么
北斗智联再添两项国家级认证
半导体支出逐渐集中化 Intel、三星和台积电占比近六成
《炬丰科技-半导体工艺》硅片清洗技术的演变
Intel酷睿i5-9400F怎么样 值不值得买
南沙岛礁官员生活极大改善!畅游4G网络全覆盖绿植面积扩大
TI为智能音箱和回音壁提供优质音效及综合保护
关于L-com USB奇异博物馆的性能分析和应用
lp7510各引脚功能电压资料