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

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

3天内不再提示

什么是宏内核、微内核?

jf_78858299 来源:码农的荒岛求生 作者:码农的荒岛求生 2023-02-17 14:32 次阅读

操作系统和普通的大型应用程序项目类似,都涉及代码组织方式的问题,但操作系统的独特之处在于其核心部分必须运行在内核态,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关于复杂指令集与精简指令集的设计一样分成了两派, 关于宏内核与微内核孰优孰劣争论至今依然没有定论

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

    关注

    37

    文章

    6818

    浏览量

    123319
  • 硬件
    +关注

    关注

    11

    文章

    3323

    浏览量

    66212
  • 代码
    +关注

    关注

    30

    文章

    4786

    浏览量

    68563
  • 微内核
    +关注

    关注

    0

    文章

    58

    浏览量

    13431
收藏 人收藏

    评论

    相关推荐

    RTOS的实时内核内核解析

    什么功能以及实现什么结构,不同的操作系统设计者有不同的回答。 与内核相对的是内核的概念。 内核
    发表于 02-19 06:36

    windows内核的相关资料推荐

    Linux 是内核或者单内核,windows是内核,最大的区别是所有的内核功能都被整体编译在
    发表于 12-16 07:52

    什么是内核_内核的发展历史

    内核设计的基本思想是简化内核功能,在内核之外的用户态尽可能多地实现系统服务,同时加入相互之间的安全保护。内核只提供最基础的服务,比如多进程
    的头像 发表于 08-14 17:20 1.2w次阅读
    什么是<b class='flag-5'>微</b><b class='flag-5'>内核</b>_<b class='flag-5'>微</b><b class='flag-5'>内核</b>的发展历史

    高性能混合微内核操作系统RT-Thread Smart达到业界领先的技术水准

    通常来讲操作系统分为内核内核两种不同的架构,如下图所示,操作系统中分为了用户域和核心域两个地址空间,
    的头像 发表于 09-11 15:33 2959次阅读
    高性能混合微<b class='flag-5'>内核</b>操作系统RT-Thread Smart达到业界领先的技术水准

    浅谈鸿蒙操作系统的内核

    华为在松山湖的华为开发者大会上正式宣布了鸿蒙操作系统,该系统其中一个亮点是 内核。华为声称,内核的启用,使其速度大大提升,并且在安全性上产生变革性突破,
    的头像 发表于 10-13 12:36 6160次阅读

    Rk3399麒麟Linux系统分类介绍

    有哪些,基于linux哪个版本呢?联智通达为您解答: 银河麒麟 银河麒麟系统操作系统借鉴了 Linux、FreeBSD、Mach 和 K42 等操作系统内核技术,兼顾内核
    的头像 发表于 01-15 14:16 3570次阅读

    鸿蒙系统优势在哪里?

    、智慧屏等智能终端。 鸿蒙系统优势二:华为harmony os打破设备与设备之间的兼容性难题,甚至是兼容安卓软件。 鸿蒙系统优势三:鸿蒙操作系统的核心技术是区别于安卓内核内核技术
    的头像 发表于 06-21 16:42 1.1w次阅读
    鸿蒙系统优势在哪里?

    鸿蒙系统设计:内核vs内核的基础逻辑

    当鸿蒙OS宣布开源的时候,各种空洞的炒作,几乎把国产操作系统的技术本质掩盖了,虽然笔者没亲眼见过鸿蒙的代码,也没用方舟成功编译什么程序,不过当华为官宣鸿蒙将使用内核的时候其实这款OS的风格就已经
    的头像 发表于 03-23 15:01 4471次阅读

    Rk3399麒麟Linux系统有哪些,基于linux哪个版本

    有哪些,基于linux哪个版本呢?联智通达为您解答: 银河麒麟系统操作系统借鉴了 Linux、FreeBSD、Mach 和 K42 等操作系统内核技术,兼顾内核
    发表于 01-19 15:35 4739次阅读

    内核内核的比较与分析

    混合内核实质上也是内核,而外内核是一种比较极端的设计方法,目前还处于研究阶段,所以我们就着重讨论内核
    发表于 03-17 16:05 11次下载
    <b class='flag-5'>微</b><b class='flag-5'>内核</b>与<b class='flag-5'>宏</b><b class='flag-5'>内核</b>的比较与分析

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

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

    【Linux内核】从小小的定义窥探Linux内核的精妙设计

    【Linux内核】从小小的定义窥探Linux内核的精妙设计
    的头像 发表于 08-31 13:30 1940次阅读

    Linux内核中的/container_of分析

    今天在看平台设备实现的时候,看到to_xxx开头的“函数”。包括在内核中也有很多此类的“函数”,其实他们都是container_of的。因为内核是链表和结构体的世界,因此内核中有大量
    发表于 06-23 14:26 396次阅读
    Linux<b class='flag-5'>内核</b>中的<b class='flag-5'>宏</b>/container_of分析

    鸿蒙使用的是内核

    我们常说,看一个系统是不是自研,就看它的内核,常见的内核分为:内核内核,当然还有两者结合体
    的头像 发表于 01-30 16:43 482次阅读
    鸿蒙使用的是<b class='flag-5'>微</b><b class='flag-5'>内核</b>?

    QNX与Linux基础差异对比

    对于QNX系统和Linux系统的内核差异,我们抛开内核内核之类的争议不谈。单纯从开发应用的角度而言,QNX和Linux系统的差异到底有
    发表于 04-17 10:52 761次阅读