0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

操作系统核心部分:什么是宏内核、微内核

strongerHuang 来源:码农的荒岛求生 作者:码农的荒岛求生 2022-05-27 09:05 次阅读

操作系统和普通的大型应用程序项目类似,都涉及代码组织方式的问题,但操作系统的独特之处在于其核心部分必须运行在内核态,kernel model,所谓内核态严格讲是指在该状态下程序拥有对硬件(hardware)的所有控制权,运行在用户态的程序做不到这一点。

有的同学可能会有疑问,操作系统(或者说内核)不都是核心部分吗?严格来讲像进程管理调度、内存管理等就是核心部分,但像驱动等就不是那么核心了,那么这一部分也需要放在内核态吗?

围绕这一划分,出现了两种操作系统的设计方式,关于这两种设计方法的争论就和复杂指令集(CISC)与精简指令集(RISC)哪个更好一样至今没有非常明确的定论。

大一统,全部运行在内核态

最简单的划分就是没有划分,我们可以把所有内核代码放在内核态,内核中的任何代码都拥有控制硬件的全部特权,显然这种设计方法非常简单,因为操作系统设计者不用费心去想哪一部分该放在内核态。

由于全部内核程序都运行在内核态,编译好的内核程序就是一个单独的二进制可执行文件,这时的操作系统运行起来后就是一个大进程,所有内核代码运行在一个单独的地址空间中,这和我们实现的稍微复杂的单进程应用程序类似,这种大一统的设计就是所谓的宏内核,monolithic kernel,个人认为叫“一体化内核”更形象些。

af873040-dd55-11ec-ba43-dac502259ad0.png

这种组织方式和TCP/IP协议栈的分层实现有点类似。

现在内核代码已经组织好了,毕竟内核是为上层应用提供服务的,那么上层应用该怎样调用内核代码呢?这就是系统调用的作用,system call。

af9a9e78-dd55-11ec-ba43-dac502259ad0.png

上层应用程序通过系统调用与内核进行交互。

由于内核代码唯一同一个地址空间中,因此内核中各部分的交互极为简单,就是普通的函数调用,文件系统中的某块cache可以非常容易的被虚拟内存系统共享使用。

但宏内核也是有缺点的,由于内核代码位于同一个地址空间,代码趋于复杂化,复杂就容易出错,但内核和普通程序不同,一旦内核中某一模块出现bug将导致整个内核崩溃,底层的内核崩溃后上层的应用程序就无法继续正常推进,整个系统就下图一样。。crash

当然也有人不在乎在这一点,Linus认为内核中有bug正常,有bug就找到它、修复它而不是用某种机制试图忽略它,没错,C++中的异常就是试图忽略bug的机制,这就是为什么很多公司的规范中禁止使用异常的原因。

总之,内核崩溃后就必须重启计算机。

保留核心,非必要不留在内核

为减少内核崩溃的风险,一个简单的办法就是让内核尽量精简,只保留核心部分运行在内核态,其它代码以用户态进程的形式运行,就像这样:

afe8222e-dd55-11ec-ba43-dac502259ad0.png

运行在用户态的操作系统程序被称为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关于复杂指令集与精简指令集的设计一样分成了两派,关于宏内核与微内核孰优孰劣争论至今依然没有定论。

审核编辑 :李倩

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Linux
    +关注

    关注

    87

    文章

    10943

    浏览量

    206546
  • 操作系统
    +关注

    关注

    37

    文章

    6204

    浏览量

    121727
  • 微内核
    +关注

    关注

    0

    文章

    54

    浏览量

    13378

原文标题:操作系统如何实现:什么是宏内核、微内核

文章出处:【微信号:strongerHuang,微信公众号:strongerHuang】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    #操作系统原理 用户线程和内核线程

    内核操作系统
    电子技术那些事儿
    发布于 :2022年10月17日 22:31:14

    #硬声创作季 #操作系统 操作系统-12 内核级线程实现-1

    内核操作系统
    水管工
    发布于 :2022年11月04日 09:30:49

    #硬声创作季 #操作系统 操作系统-12 内核级线程实现-2

    内核操作系统
    水管工
    发布于 :2022年11月04日 09:31:11

    #硬声创作季 #操作系统 操作系统-12 内核级线程实现-3

    内核操作系统
    水管工
    发布于 :2022年11月04日 09:31:31

    #硬声创作季 #操作系统 操作系统-12 内核级线程实现-4

    内核操作系统
    水管工
    发布于 :2022年11月04日 09:31:53

    内核操作系统有什么好处?

    。可见Windows在内核之上来说的确是一个很干练的系统。其实这是微软的一贯作风,就算是目前我们使用的Win 7旗舰版其内核也是十分短小精悍的。那么微内核操作系统究竟是有什么好处呢?首
    发表于 01-11 13:11

    RTOS的实时内核内核解析

    使得CPU的利用更为有效。 需要指出的是,实时内核并不等于实时操作系统,实时内核只是实时操作系统的一部分
    发表于 02-19 06:36

    HarmonyOS鸿蒙操作系统之什么是“基于内核的全场景分布式操作系统”?

    HarmonyOS鸿蒙操作系统之什么是“基于内核的全场景分布式操作系统”?即使作为理工科的人咋一眼看上去似乎也不太懂这是什么,就像区块链这个概念刚出来一样,普通人都是一脸懵B(当然现
    发表于 09-23 17:06

    嵌入式操作系统内核研究

    嵌入式操作系统是嵌入式系统应用的核心。而内核完成操作系统核心的功能,本文通过对两种嵌入式
    发表于 07-30 14:55 22次下载

    什么是操作系统内核

    什么是操作系统内核 操作系统内核是指大多数操作系统核心部分。它由
    发表于 06-17 07:23 9589次阅读

    RTX实时操作系统内核演示

    本文档详细介绍了 RTX实时操作系统内核演示教程
    发表于 08-25 15:52 9次下载

    为什么要选择微内核操作系统

    例如原来在宏内核操作系统中,用户应用程序是通过系统调用,陷入到内核中,然后再读取、访问文件。而在微内核操作系统中,则是用户应用程序通过发送I
    的头像 发表于 06-03 14:35 3718次阅读

    什么是宏内核、微内核

    操作系统和普通的大型应用程序项目类似,都涉及代码组织方式的问题,但操作系统的独特之处在于其核心部分必须运行在内核态,kernel model,所谓
    的头像 发表于 02-17 14:32 1224次阅读
    什么是宏<b class='flag-5'>内核</b>、微<b class='flag-5'>内核</b>?

    Linux 是操作系统还是内核

    内核是每个操作系统的中心。这不仅仅是 Linux 的事情。Windows 和 macOS 也有内核
    发表于 03-15 10:05 804次阅读

    操作系统中抢占式和非抢占式内核的区别

    操作系统一般分为抢占式内核和非抢占式内核,通常RTOS都是抢占式内核。你知道抢占式内核和非抢占式内核
    的头像 发表于 05-29 10:47 674次阅读
    <b class='flag-5'>操作系统</b>中抢占式和非抢占式<b class='flag-5'>内核</b>的区别