MINIX3  内核整体架构回顾及内核定
性分析

12.1 注意事项

由于本文档不对 I/O 文件系统做出分析,所以在此不对 MINIX3 整体做出一个分 析,本章主要是针对内核进程分析.并且这里的模型建立是非常理想化的。

12.2 MINIX3 架构

MINIX3 的设计理念就是设计一个比当前主流的系统更加稳定和可靠系统。从而
MINIX3 也就是提出一个非常经典的模式:就是系统服务器进程的概念。这些系
统服务器进程是外核的一部分,但是可以和内核通信。最为重要的设计理念是这
些服务器进程既然作为用户进程的一部分,那么他们具有绝对的独立性,每一个
进程都是相互独立存在的。每一个进程都是运行在可靠的内核上。如下图所示:

这种设计理念和传统的 LINUX/UNIX 的设计方法是不一样的。在 LUNIX/UNIX
中,设计是将服务器进程都移到内核中,也就是服务器进程之间就会产生绝对的
联系,就是一个单核系统。传统 LINUX/UNIX 的设计理念就会导致一个非常重
要的问题:就是内核 bug。代码量越大,内核 bug 就会越多,这个是无法避免的。
所以 MINIX3 就从设计方法来改变这个问题。也就是提出了上面的设计方法。
同时,MINIX3 设计者也是保持用一些直白的技术保持代码的简单性,而不会为了
这个所谓的目标资源优化而做出复杂的代码。事实上,MINIX3 就是用了非常简单

188

的 MMU 机制(在这个版本的内核中,MMU 其实非常小,小道不会单独出一个 服务进程来,而是附属在 PM 进程),甚至都没有虚拟内存的概念。这个也主要 体现了一种设计简单性的理念。

对于内核部分,我们从前面章节的也能够分析出来,微内核主要就是上图所示的 时钟任务,中断异常处理机制,进程通信,系统任务,调度机制。这几个都是一 个操作系统内核所必须具备的。必须要在内核中。

对于用户态的进程而言,MINIX3 所赋予的进程功能也是非常丰富的,就前面章 节的分析而言,它具备了很多内容,比如进程间的通信,通过调用内核消息机制 原语。拥有自己的独立地址空间等。而进程间的通信也是通过相应的消息机制实 现,这种消息机制也能够实现一个非常完美的异步过程。如果没有接受消息,就 阻塞自己。这也就表明了一个非常基本点:进程可以实现异步。同样系统进程间 还提出了一个通知,这个通知是为了提供一个更加高效的消息通信而设立的。 对于服务器进程,为了能够和 POSIX 接上轨,在服务器进程端提供了符合 POSIX 标准的系统调用,等待准备接受用户的调用。

事实上,MINIX3 的服务器进程还提供了自我修复的功能,具体内容需要参考相 关文献。

Minix3  设计者提出 MINIX3  的设计非常可靠的是点理由[1],简要在这里描述一
下:

1 运行在内核态模式下的代码数量是非常小的,真正内核态的模式下的代码就只 要几千行,和 LINUNX/UNIX/WINIDOWS 的几千万行相比,差距还是非常大的。 MINIX3 能够保证单独一个程序员能够阅读完整个内核。

2 尽管将服务器移到内核外,不能避免 bug,但是有一点,它可以大大的减少 bug 的存在。

比如一个驱动进程 如果是在内核态的话,它可以执行关开中断命令,只要有一 个语句出问题,就可能毁掉整个内核。

3(I/O 我们没有接受,但是这点好理解)我们认为驱动器是运行在用户态,也就 没有办法执行关中断 开中断这种特权指令。这也就为提供一种保护而做出了不 朽的努力。

4 进程间的通信是通过使用固定格式的消息模式,这样对于分配固定的空间是很 有用的,这样也是提供了一种安全的方法。(当然,我个人认为这种方法会导致 了一种呆板)

5 中断和消息传递都是非常简单的,中断发生时,相关驱动器就会被通知,如果
驱动器等待,则就接受,不等待,就阻塞。这种简单的模式也是提供一种安全的
方法

剩余几点就参看[1],主要是由于剩余几点都涉及到驱动那一块,在这里就不给予 分析。

12.3MINIX3 的系能分析

单独将 MINIX3 和 LINUX/UNIX 比较,MINIX3 是呈现弱势的,但是究竟是因
为核而导致的吗?这个不能完全肯定,比如在服务器进程中,MINIX3   和
LINUX/UNIX 是采用不同的文件系统,不同的内存管理,这个很难去比较核的
内容。事实上,如果要单独比较核,外核算法完全一致。事实上,这种情况是不

189

可能实现的。所以就性能的比较还是和以前的版本比较比较好:

这里我附录衣服图[1]呈现出 MINIX2 和 MINIX3 的一个性能比较:

我们可以看到,MINIX3 和 MINIX2 相比较,的确要慢,大概要慢 1.12%,但是 MINIX2 的设计理念和 MINIX3 有很大的差别。MINIX3 的安全性得到很大的提 高。MINIX3 的设计者也认为,用这种速度的降低来换取安全,是值得的。MINIX3 的设计理念就是可靠性。

MINIX3 单独内核模块的分析:

整体而言,每一个模块都不是相对独立的,都是相互调用的,相互产生联系的, 就相当于一个有向连通图。整体而言,如下图所示:

190

这里的内核中心可能是上面四种的任何一个部分。体现了一种间的反应。 我们现在来比较详细的看看这几个模块的相互发生怎么样的联系:

191

这个图明显是一个有向有环图,没有始发点,就随便跳出一个分析:

从时钟任务开始把:时钟任务由硬件触发,准确的说是时钟硬件触发时钟中断,
也就是到了中断机制,之后中断机制进行相关处理触发到消息机制,消息机制触
发时钟机制运行。时钟机制又会调用调度算法,调度算法,调度算法可能会触发
消息机制,消息机制也就触发了系统任务调用相关函数。这里从时钟机制遍历了
图的大部分。

调度机制:    调度机制的话,与外界的接口就是 enqueue/dequeue 函数,时钟任务 和消息机制都会触发整个调度机制,调度机制相对比较隔离,最多就是想调用系 统函数,通过消息机制向系统任务发送。

中断机制:中断机制是内外接口的一个非常重要的机制,在内核部分,主要可能 就是由时钟触发,中断机制会导致什么内核动作呢?如果我把这里的中断机制包 括了陷入,那么他就会触发_sys_call,这里会触发消息机制,消息机制自然可能 从各个出口出去。如果仅仅就是中断机制,它所完成的动作非常的简单,就是做 出一些处理,就返回。

系统任务:主要就是接受消息机制的调用,它的功能也是相对比较独立,接口就
是调用消息机制所传来的向量号,之后调用相关的函数,之后就完成了它的任务。
这就是内核的微观的分析。这里讲解的比较简单,具体还是要参考各个章节分析。

12.4 MINIX3 内核部分定量分析尝试

进程 U1,U2,„„„„Un 为用户进程

系统内核进程有 CLOCK,SYSTEM 记为:CP,SP,

中断系统 通信机制系统,调度机制不隶属任何一个进程。记中断系统为 IP,通信机 制记作为 IPC,调度机制记 SC

记一个单元花费时间通用记号为:T

为了建立一个合适的理想模型:我们认为单位时间内服务器进程或者是用户进程 会有 N1

次中断请求,发送 N2 次消息。消息处理通用平均处理时间记为 TIPC,调度机制 通用处理时间为 TSC,时钟内核通用处理时间为 TCP,系统任务通用处理时间为 TSP.中断通用处理程序耗时是 TIP,剩下的变量就会遇到时就给予介绍!

192

定理一:有 N 次消息进入内核,则内核一定会调用 N 次调度通用处理函数。

证明分析:试想下消息机制的原理,如果一个进程发送一个消息,如果对方处于 阻塞状态,则自己就会调用一次 enqueue,如果对方在就就绪状态,则自己就会 调用一次 dequeue。一个进程的接受过程也是这样处理的。所以 N 此消息进入内 核,则内核一定调用 N 次调用函数。

定理二:N 次消息进入内核,这 N 次消息都是使得 SYSTEM 进程进入调度队列 证明分析:内核中只有  2  个进程,消息机制就是从 A 进程发到 B 进程,并且 CLOCK  进程只接受时钟硬件中断,所以最终进入内核的消息机制只会进入 SYSTEM 进程。

引理:由 N 次消息进入内核会导致触发 N 次消息。

分析:由定理 2 知,N 次消息进入内核都是到了 SYSTEM 进程,由 SYSTEM 进 程源码知最终会发送一个 lock_send()进程,也就是说,其会触发 N 次消息
引理:N 次外核中断会触发 N 次内核中断处理程序。

这个引理非常的显然,就此忽略。

现在我们从内核的角度来分析:内核的相互触发过程最核心的就是时钟硬件产生

193

的中断。在这里,我们同样定义几个变量:

单位时间内,时钟产生硬件中断的次数是 H1,触发消息机制的次数是 H2  ,这 H2 会触发 H3 次调度算法函数。

只分析整个内核消耗的总平均时间$
定理 3:

$=N1*TIP+N2*(TSP+2*TIPC*TSC*2)+(H1*TCP+H2*TIPC+H3*TSC)

证明:整体内核消耗时间是包括处理外核发来的消息,外核产生的中断,以及内 核产生的时钟中断。每次外核产生的中断导致了耗时 TIP。所以这一部分等于 N1*TIP。每次外核发送消息到内核,其会产生一个消息处理耗时,一个调度函数 消耗,一个消息发送耗时,以及这个消息发送耗时导致的调度函数消耗,还有一 个系统通用处理程序耗时。也就是 TSP+2*TIPC+2*TSC

内核时间中断,就以 H1 次为例,H1 触发 H1 次时间中断处理通用程序耗时,其 中有 H2 次触发消息机制,这 H2 次中又会触发 H3 次调度函数。所以耗时就是 H1*TCP+H2*TIPC+H3*TSC

最终$=$=N1*TIP+N2*(TSP+2*TIPC*TSC*2)+(H1*TCP+H2*TIPC+H3*TSC)

证毕

最后结束语:这个章节只是一个常识性的分析,特别是在量化方面,量化方面非 常难,这里很多问题都没有考虑到,建立的模型是非常理想化的。但是真正的实 际的 MINIX3 投入真正的使用时,会比这个要复杂的多。但是这种尝试的量化分 析对进一步了解内核各个怎么相互作用和相互调度有非常大的帮助!最后祝读者 能够有个轻松快乐的内核之旅!

MINIX3 内核整体架构回顾及内核定 性分析的更多相关文章

  1. 浅析MyBatis(一):由一个快速案例剖析MyBatis的整体架构与运行流程

    MyBatis 是轻量级的 Java 持久层中间件,完全基于 JDBC 实现持久化的数据访问,支持以 xml 和注解的形式进行配置,能灵活.简单地进行 SQL 映射,也提供了比 JDBC 更丰富的结果 ...

  2. Linux内核的整体架构

    Linux内核的整体架构 作者:蜗蜗 发布于:2014-2-21 13:23 分类:Linux内核分析 原文:http://www.wowotech.net/linux_kenrel/11.html ...

  3. Linux内核的整体架构简介

    1. 前言 本文是“Linux内核分析”系列文章的第一篇,会以内核的核心功能为出发点,描述Linux内核的整体架构,以及架构之下主要的软件子系统.之后,会介绍Linux内核源文件的目录结构,并和各个软 ...

  4. MINIX3 内核时钟分析

    MINIX3 内核时钟分析  4.1 内核时钟概要  先想想为什么 OS 需要时钟?时钟是异步的一个非常重要的标志,设想一下,如 果我们的应用程序需要在多少秒后将触发某个程序或者进程,我们该怎么做到? ...

  5. 深度解读MRS IoTDB时序数据库的整体架构设计与实现

    [本期推荐]华为云社区6月刊来了,新鲜出炉的Top10技术干货.重磅技术专题分享:还有毕业季闯关大挑战,华为云专家带你做好职业规划. 摘要:本文将会系统地为大家介绍MRS IoTDB的来龙去脉和功能特 ...

  6. 【深入浅出jQuery】源码浅析--整体架构

    最近一直在研读 jQuery 源码,初看源码一头雾水毫无头绪,真正静下心来细看写的真是精妙,让你感叹代码之美. 其结构明晰,高内聚.低耦合,兼具优秀的性能与便利的扩展性,在浏览器的兼容性(功能缺陷.渐 ...

  7. [转]Android App整体架构设计的思考

    1. 架构设计的目的 对程序进行架构设计的原因,归根到底是为了提高生产力.通过设计使程序模块化,做到模块内部的高聚合和模块之间的低耦合.这样做的好处是使得程序在开发的过程中,开发人员只需要专注于一点, ...

  8. jQuery整体架构源码解析(转载)

    jQuery整体架构源码解析 最近一直在研读 jQuery 源码,初看源码一头雾水毫无头绪,真正静下心来细看写的真是精妙,让你感叹代码之美. 其结构明晰,高内聚.低耦合,兼具优秀的性能与便利的扩展性, ...

  9. 《深入理解bootstrap》读书笔记:第二章 整体架构

    一.  整体架构   1. CSS-12栅格系统 把网页宽度均分为12等分(保留15位精度)--这是bootstrap的核心功能. 2.基础布局组件 包括排版.按钮.表格.布局.表单等等. 3.jQu ...

随机推荐

  1. Android first---文件读取(登录案例编写为主)

    以android登录案例来介绍文件的读取与androidAPI给予的方法 第一步:绘制界面 绘制方法:在线性布局下面设置相对布局 代码部分: <LinearLayout xmlns:androi ...

  2. c++实现蛇形矩阵总结

    蛇形矩阵,百度了一下,是这么一个东西: 像一条蛇一样依次递增. 我想,竟然做了螺旋矩阵,那做一下这个吧.在之前的螺旋矩阵的main函数基础上,写个函数接口就行了,这一次做的很快,但是这个矩阵感觉比螺旋 ...

  3. [问题2015S07] 复旦高等代数 II(14级)每周一题(第八教学周)

    [问题2015S07]  设 \(A\) 为 \(n\) 阶复方阵, 证明: 存在 \(n\) 阶非异复对称阵 \(S\), 使得 \(A'=S^{-1}AS\), 即 \(A\) 可通过非异复对称阵 ...

  4. Web页面速度测试工具

    开发框架的时间,想测试单例和多例下对性能的影响,找了下没有特别简单易用的测试工具. 估摸着搞了一个小工具. 针对.net Framework的2.0,3.5,4.0版本. WebHttpTest2.0 ...

  5. 17.KVM安装之虚拟磁盘,安装脚本

    1.创建磁盘 vm.list 指定虚拟磁盘名称和主机名 create_vm.sh    #创建vm.list中的虚拟磁盘,并指定大小100G #!/bin/bash VM_DIR="/opt ...

  6. springMVC简单示例

    1.新建web工程 2.引入springframework架包 3.配置文件 web.xml <?xml version="1.0" encoding="UTF-8 ...

  7. Ubuntu快捷键

    https://linux.cn/article-3025-1.html 超级键操作 1.超级键(Win键)–打开dash. 2.长按超级键– 启动Launcher.并快捷键列表. 3.按住超级键,再 ...

  8. POM.xml 标签详解

    pom作为项目对象模型.通过xml表示maven项目,使用pom.xml来实现.主要描述了项目:包括配置文件:开发者需要遵循的规则,缺陷管理系统,组织和licenses,项目的url,项目的依赖性,以 ...

  9. 查看rpm和war包内容

    解压rpm包的内容:(没有安装,就像解压tgz包一样rpm包)rpm2cpio *.rpm | cpio -div 解压war包的内容: jar -xvf project.war 解压到当前目录

  10. wifidog 配置中文说明

    #网关IDGatewayID default#外部网卡ExternalInterface eth0#无线网卡GatewayInterface eth0#无线IPGatewayAddress 192.1 ...