Monolithic Kernel

无论是Windows还是Linux等等,这些寻常使用的操作系统,都是用内核和管理和使用硬件的。

宏内核。

Monolithic,词典义是『单一的,庞大的』,简单理解,就是内核的所有功能,从文件系统,到内存管理,到CPU调度,等等等等,都放在内核态中。这样做有一个很大的好处,那就是所有这些功能都在同一个地址空间下,大家做通信会非常方便,而且通信的成本肯定也是低的,实现起来会快糙猛一些。就是很莽很厉害。

但是,这样也会导致一些其他问题。我觉得最大的问题就是代码复杂度会提高。Linux Kernel的代码量太美不看。同时,这样也会导致容错性不是很好,只要一个地方出了问题,会导致整个Kernel都挂掉。

Micro Kernel

那既然Monolithic Kernel有这样的问题,做研究的人一定不会放过这样的好机会,于是就有了微内核的概念。所谓微内核,是指内核只提供最必要的功能,比如IPC,内存管理,CPU调度等等。而其他,诸如文件系统,网络IO等等,都放在用户态来实现。

这样做的好处首先是内核变小了,内核是常驻内存的,小了自然就节约了内存的空间。但是,这样的性能就会不如很莽很厉害的Monolithic Kernel要好,因为IPC通信的overhead还是有一些的。

Hybrid Kernel

那既然Micro Kernel和Monolithic Kernel都有问题,能不能把两个结合一下,互相中和呢。

PPAP (Kernel Version)
I have a Monolithic Kernel.
I have a Micro Kernel.
Bow!
Hybrid Kernel!

这大概是研究的惯用套路,一个事情有两种极端的做法,然后中和一下,就有了第三种做法。那Hybrid Kernel就是把一部分不常使用的内核模块,或者是原本需要的时间就很长,因此IPC的overhead看起来就不是那么夸张的功能,移出内核,而其他的就会放在内核里。

 

之前说到的Monolithic Kernel也好,Micro Kernel也好,它们对资源的保护和管理都是在内核里去做的,也就是说,它们都是先对硬件做抽象,然后向上不直接暴露硬件,而是暴露硬件的抽象。一个例子,硬盘是硬件设备,但是我们的应用程序看到的是一个个的文件,文件本身就是一种抽象。而应用程序,是没办法直接操作硬件的,只能跟操作系统提供的抽象打交道。

 

------------------越是喧嚣的世界,越需要宁静的思考------------------ 合抱之木,生于毫末;九层之台,起于垒土;千里之行,始于足下。 积土成山,风雨兴焉;积水成渊,蛟龙生焉;积善成德,而神明自得,圣心备焉。故不积跬步,无以至千里;不积小流,无以成江海。骐骥一跃,不能十步;驽马十驾,功在不舍。锲而舍之,朽木不折;锲而不舍,金石可镂。蚓无爪牙之利,筋骨之强,上食埃土,下饮黄泉,用心一也。蟹六跪而二螯,非蛇鳝之穴无可寄托者,用心躁也。