`
kongweile
  • 浏览: 508279 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

微内核(microkernel)相关

 
阅读更多

from : http://www.yandong.org/archives/191

介绍


WIKI上的解释是:在计算机科学中,微内核是一个近乎最小的软件集合,但具有能够提供实现操作系统所需的机制。 

In computer science, a microkernel is the near-minimum amount of software that can provide the mechanisms needed to implement an operating system (OS).   —wiki

微内核把硬件驱动,协议栈,以及文件系统等都放入用户空间,以保持较小的代码规模。微内核的代码一般在10000行一下,像Minix不足6000行代码,而高于20000行一般都归于monokernel。 

本质上说,微内核可以被看作是对传统操作系统共性的进一步抽象,从某种意义上说可以被称作是操作系统的操作系统

 

时代背景


     开始的内核都很小,主要是因为电脑很小。随着电脑功能的增强和硬件的发展等因素,内核越来越大。BSD unix开启了大内核的时代。内核规模的增长使内核更容易出现bug,而且不方便管理。而微内核的出现正是为了解决这些问题。微内核发展与上世纪80年代。与之相对的是,宏内核(mono kernel)。虽然微内核在当时是一个非常惹得话题,应用领域之中,mono kernel占据这主导地位。

发展


第一代: Mach是最早的微内核系统,由卡内基梅隆大学发展的。它从1985年运行到1994年,到Mach 3.0版结束。Mach的研究到至今似乎是结束,虽然有许多商业化操作系统,如NEXTSTEP 与 OPENSTEP,特别是 Mac OS X都是使用Mach或其衍生系统。Mach的虚拟内存(VM)系统也被BSD的开发者用于CSRG,并出现在BSD衍生的系统中,如FreeBSD。

     最为悲惨的遭遇是,Mac OSX与FreeBSD并未保留Mach首倡的微核心结构,除了Mac OSX继续提供微核心于内部处理通讯以及应用程式直接控制。更有些滑稽的是,在microkernel流行的时候,windows曾经把UI部分拿出kernel,可当microkernel之风过去了的时候,微软又把部分底层的UI放回了kernel。微软总是最后一个吃螃蟹的人,当它都尝试microkernel,足以说明microkernel是多么火热。可microkernel为什么又被冷落了呢?性能。

ps:卡内基梅隆大学位于痞子堡,是美国计算机科学重镇,排名前五。
ps:Mac OS X (使用XNU 核心)基于Mach3.0
ps:NEXTSTEP基于Mach2.0

第二代:L4可以看作是Mach的改进。由德国的 GMD 设计。GMD 是德国国家信息技术研究院,相当于中科院计算所加上软件所。

    在九十年代后期,微内核迎来了其生命中的第二春。一些研究人员认真分析了微内核系统性能差的原因,指出其性能差并非根本内在的因素造成,而是设计实现的失误。为什么这么说呢?因为早起的微内核系统大多是由 Mono Kernel 一步步逐渐改进而来。其很多设计并未发生重大改变。他们虽然被称为微内核,但其代码量还是很大。例如,Mach 3 内核支持 140个系统调用,代码量为 300K 字节。为证明其论点,他们设计并实现了几个性能远超第一代的微内核操作系统,我们把它们称为第二代微内核系统]。其中的一个代表作品就是 L4。

第三代:seL4是一组基于微内核构架的操作系统内核,澳大利亚研究组织NICTA创造了一个新的L4版本,称为Secure Embedded L4(简写seL4),宣布在世界上率先开发出第一个形式化机器证明的(formal machine-checked proof)通用操作系统。

微内核的发展方向


微内核性能分析


  理想情况下,内核中仅留下 Address Space Support(地址空间支持),IPC (InterProcess Communication,进程间通讯),和Scheduling(调度),其他功能模块做为用户进程运行。其中IPC是极其重要的组成部分,因为模块间要是想通信的话,就的靠IPC了。IPC的性能直接决定微内核的性能。可不如人意的是,虽然IPC已经广泛应用,但其性能并不理想,从而成为微内核的性能瓶颈。

   IPC的性能有多么差呢?我们来看看比较数据。微内核系统中 IPC 性能不断提高,但到 90 年代初似乎达到了顶峰。Mach 3 的 IPC 最好性能大约是 115 µs (在 486-DX 50 机器上),通常需要200 µs。对其它微内核系统也大致如此。当时许多研究人员认为,有 100 µs 左右的时间是 IPC 的固有消耗,这一时间已无法缩短。但是与之相比,在同样硬件平台上,一个 UNIX 系统调用只需要20 µs, 好过微内核系统 10 倍。

   到了L4的时代,微内核的性能得到了很好的改善。L4 内核支持三种抽象概念:地址空间,线程,和 IPC。他只提供 7 个系统调用,只有 12K 字节代码。在 486-DX50 机器上,一个地址空间切换 IPC, 8 字节参数传递,只需要 5 µs。如果参数量为 512字节,只需要 18 µs。也就是说,L4的IPC比第一代微内核的IPC快20倍以上,甚至比传统操作系统的IPC还要快。

    既然IPC的性能已经得到改善?那么微内核还面临什么问题呢?L4所做的改变只能使微内核在单服务器上的性能稍稍优于传统的系统。但是在多服务器上,和mono systems仍然木有可比性。为什么如此?说来话长,参见IPC机制吧。

GNU/Hurd


说起这,就要说说蛋疼而旷日持久的GNU工程。GNU 工程 创始于一九八四年,旨在开发一个完整 GNU 系统。GNU 自己的内核 Hurd 仍在开发中,离实用还有一定的距离。因此,现在的 GNU 通常使用 Linux 内核。这样的组合即为 GNU/Linux 操作系统。已经有上百万人在使用 GNU/Linux,但他们中的很多人把它误称为“Linux”。GNU Hurd的开发走过一段极其苦逼的历史,开始它基于由卡內基美隆大学的 Mach 3.0的,后来卡内基中止了Mach计划,于是自由软件基金会便转向犹他大学的Mach4,后来犹他也终止Mach计划,不甘心的自由软件基金会的人于是决定自己发展Mach,叫GNU/Mach。2002年推出GNU/Mach1.0,过了几年推出2.0,可不知什么原因2.0被放弃,重新回到1.X版本。再后来,Mach在业界的研究都被终止了,L4兴起,自由软件那帮可怜的娃不得不放弃之前近二十年的努力,将Hurd移植向L4。

所以说GNU Hurd 是一系列基于 GNU Mach 或者 L4 微内核的守护进程,这一套守护进程最终形成了 GNU 操作系统。之前GNU 计划从1990年开始开发 GNU Hurd,并且将它作为一个遵循 GPL 的自由软件发布。Hurd 的目标是从功能、安全性和稳定性上全面超越 Unix 内核,而同时又能保持对其的兼容性,为此 Hurd 遵守 POSIX 标准。

  “HURD”是一个间接递归缩写,来自“HIRD of Unix Replacing Daemons”,其中“HIRD”表示“HURD of Interfaces Representing Depth”。

   Hurd基于GNU Mach作微内核进行开发。这是由Richard Stallman做出的技术决定。更为滑稽的一段故事是,Stallman并不看好像linux等的monokernel,才作出使用microkernel的决定。而linux的创始人Linus Torvalds更是鄙视microkernel,认为microkernel注定是一个技术失败。而对于芸芸众生的我们,习惯了GNU/linux组合,用着linux的内核,使用着GNU的软件。

linux是否是微内核?


众多的linux是monokernel,如上面所提到的Linus Torvalds本人并不看好微内核。首先认为microkernel是一个技术失败,木有显示意义;再者,他认为没有必要为了microkernel而带来的一点蝇头小利而重写linux内核,不值得。

有哪些微内核?


  1. 上文提到的Mach, L4, seL4, hurd等
  2.  Exokernel和Rambler,都是第二代微内核
  3. BeOS曾经是一款非常伟大的微内核操作系统,没能持续发展,被Palm收购以后寿终正寝了
  4. ReactOS是一款企图兼容Windows的开源操作系统项目,不过进展十分缓慢,该项目已死
  5. Minix3,学习现代操作系统技术真正的好教材!
  6. QNX,看上去非常美好的实时+微内核。黑莓推出了一款平板PlayBook,就是使用QNX。它可能是最成功的微内核操作系统之一。
分享到:
评论

相关推荐

    微内核操作系统综述(microkernel os survey)

    1980-2000年间,microkernel操作系统被广泛研究,目的是解决macrokernel的巨大,不安全,更新困难等问题,但是,由于性能上的原因,微内核系统没有发展起来。最近cpu性能已经足够强大,微内核系统又逐渐发展,例如...

    PARAS微内核的设计The Design of PARAS Microkernel

    基于微内核的操作系统PARAS的研究与开发,用于C-DAC PARAM系列超级计算机。

    swift-MicroKernel是一个客户端微内核架构

    MicroKernel是一个客户端微内核架构。从另一个角度来看,MicroKernel提供了最佳实践,也就是说,MicroKernel也是实现了其架构思想的框架。

    microkernel:微内核

    微内核ASM & C 中的微内核除了由于未知原因在虚拟内存映射上产生偏移的 memory_service 之外,Everithing 正在工作。 这个问题使得内核无法启动第一个用户态标准进程。 任何帮助表示赞赏:)

    microkernel:服务器应用程序的微内核

    微内核服务器应用程序的微内核关于Microkernel 是 JavaScript 库,用于环境,在模块、有状态生命周期、钩子、事件、服务和资源的帮助下构建和管理服务器应用程序。 它遵循面向组件的范例。安装$ npm install ...

    microkernel-study:微内核设计博客的学习

    微内核定义: 微内核是内核的一种精简形式。将通常与内核集成在一起的系统服务层被分离出来,变成可以根据需求加入选件,这样就可以提供更好的可扩展性和更加有效的应用环境。使用微内核设计,对系统进行升级,只要...

    Mstring microkernel:实时微内核-开源

    μString微内核是Jari OS项目的一部分。 这是在Jari OS平台中使用的可抢占的实时微内核。

    microkernel-mod-alasql:用于集成 AlaSQL 数据库的微内核模块

    微内核-mod-alasql 用于集成AlaSQL数据库的微内核模块。 关于 这是一个扩展模块,服务器应用环境,增加了无缝集成AlaSQL数据库的能力。 用法 $ npm install microkernel $ npm install microkernel-mod-ctx ...

    microkernel-ext-debug:用于调试运行时处理的微内核扩展程序

    微内核扩展调试 用于调试运行时处理的微内核扩展程序。 关于 这是服务器应用程序环境的扩展过程,通过显示拓扑模块排序、状态转换和进入/离开方法调用,添加了调试微内核运行时处理的功能。 用法 $ npm install ...

    microkernel-mod-ctx:用于确定服务器应用程序运行时上下文的微内核模块

    微内核-mod-ctx 微内核模块,用于确定服务器应用程序的运行时上下文。 关于 这是服务器应用程序环境的扩展模块,添加了确定服务器应用程序运行时上下文的功能。 用法 $ npm install microkernel $ npm install ...

    microkernel-mod-logger:用于向服务器应用程序添加日志记录功能的微内核模块

    微内核模块记录器 用于向服务器应用程序添加日志记录功能的微内核模块。 关于 这是服务器应用环境的扩展模块,增加了日志功能。 用法 $ npm install microkernel $ npm install microkernel-mod-ctx microkernel-mod...

    microkernel-mod-options:用于向服务器应用程序添加命令行选项解析的微内核模块

    微内核模块选项用于向服务器应用程序添加命令行选项解析的微内核模块。关于这是一个针对服务器应用环境的扩展模块,为服务器应用添加了命令行选项解析。用法$ npm install microkernel$ npm install microkernel-mod...

    cerk:具有微内核的CloudEvents路由器

    微内核 MicroKernel负责在Scheduler的帮助下启动其他组件,并在它们之间代理消息。 MicroKernel是在cerk板条箱中实现的。 运行时间 运行时提供了调度程序和通道(发送器/接收器)实现。 调度程序负责使用特定于...

    微内核:Manycores的研究微内核

    微内核:Manycores的研究微内核

    闪闪发光:Rust Rust中的一个微内核

    闪闪发光:Rust Rust中的一个微内核

    ghost:Ghost,用于x86架构的基于微内核的爱好操作系统

    关于幽灵Ghost是用于Intel x86平台的操作系统。...特征纯微内核多处理器和多任务支持(SMP) IPC-管道,信号,消息,共享内存窗口服务器(带有自制工具包的GUI) 修补的GCC(特定于操作系统的工具链) 自制的libc

    resea:基于微内核的可入侵操作系统

    Resea [ríːseə]是从头开始编写的基于微内核的操作系统。 它旨在提供引人入胜的开发人员体验并使其易于入侵:直观了解整个设计,轻松自定义系统以及扩展功能的乐趣。 有关更多详细,请参见。 产品特点 完全基于C...

    seL4:seL4微内核

    有关seL4微内核的详细信息,包括其形式正确性证明的详细信息,请访问网站和相关的 。 引用此存储库的最新版本的DOI: 我们欢迎对seL4的贡献。 请访问该网站以获取有关。 通常不会孤立地使用此存储库,而是将其...

    Linux协议栈阅读笔记

     微内核(Microkernel kernel): 在微内核中,大部分内核都作为独立的进程在特权状态下运行,他们通过消息传递进行通信。在典型的情况下,每个模块都有一个进程。在这种设计中,微内通常作为消息转发站的角色。其...

    fiasco:Fiasco.OC微内核的开发版本

    Fiasco.OC微内核存储库该存储库包含L4Re微内核(也称为Fiasco.OC微内核)的源代码。 用户级别的应用程序不包含在此软件包中。 Fiasco用于构建灵活的系统,这些系统支持在一个系统上同时运行实时,分时和虚拟化工作...

Global site tag (gtag.js) - Google Analytics