MINIX3 内核整体架构回顾及内核定 性分析
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 内核整体架构回顾及内核定 性分析的更多相关文章
- 浅析MyBatis(一):由一个快速案例剖析MyBatis的整体架构与运行流程
MyBatis 是轻量级的 Java 持久层中间件,完全基于 JDBC 实现持久化的数据访问,支持以 xml 和注解的形式进行配置,能灵活.简单地进行 SQL 映射,也提供了比 JDBC 更丰富的结果 ...
- Linux内核的整体架构
Linux内核的整体架构 作者:蜗蜗 发布于:2014-2-21 13:23 分类:Linux内核分析 原文:http://www.wowotech.net/linux_kenrel/11.html ...
- Linux内核的整体架构简介
1. 前言 本文是“Linux内核分析”系列文章的第一篇,会以内核的核心功能为出发点,描述Linux内核的整体架构,以及架构之下主要的软件子系统.之后,会介绍Linux内核源文件的目录结构,并和各个软 ...
- MINIX3 内核时钟分析
MINIX3 内核时钟分析 4.1 内核时钟概要 先想想为什么 OS 需要时钟?时钟是异步的一个非常重要的标志,设想一下,如 果我们的应用程序需要在多少秒后将触发某个程序或者进程,我们该怎么做到? ...
- 深度解读MRS IoTDB时序数据库的整体架构设计与实现
[本期推荐]华为云社区6月刊来了,新鲜出炉的Top10技术干货.重磅技术专题分享:还有毕业季闯关大挑战,华为云专家带你做好职业规划. 摘要:本文将会系统地为大家介绍MRS IoTDB的来龙去脉和功能特 ...
- 【深入浅出jQuery】源码浅析--整体架构
最近一直在研读 jQuery 源码,初看源码一头雾水毫无头绪,真正静下心来细看写的真是精妙,让你感叹代码之美. 其结构明晰,高内聚.低耦合,兼具优秀的性能与便利的扩展性,在浏览器的兼容性(功能缺陷.渐 ...
- [转]Android App整体架构设计的思考
1. 架构设计的目的 对程序进行架构设计的原因,归根到底是为了提高生产力.通过设计使程序模块化,做到模块内部的高聚合和模块之间的低耦合.这样做的好处是使得程序在开发的过程中,开发人员只需要专注于一点, ...
- jQuery整体架构源码解析(转载)
jQuery整体架构源码解析 最近一直在研读 jQuery 源码,初看源码一头雾水毫无头绪,真正静下心来细看写的真是精妙,让你感叹代码之美. 其结构明晰,高内聚.低耦合,兼具优秀的性能与便利的扩展性, ...
- 《深入理解bootstrap》读书笔记:第二章 整体架构
一. 整体架构 1. CSS-12栅格系统 把网页宽度均分为12等分(保留15位精度)--这是bootstrap的核心功能. 2.基础布局组件 包括排版.按钮.表格.布局.表单等等. 3.jQu ...
随机推荐
- Android first---文件读取(登录案例编写为主)
以android登录案例来介绍文件的读取与androidAPI给予的方法 第一步:绘制界面 绘制方法:在线性布局下面设置相对布局 代码部分: <LinearLayout xmlns:androi ...
- c++实现蛇形矩阵总结
蛇形矩阵,百度了一下,是这么一个东西: 像一条蛇一样依次递增. 我想,竟然做了螺旋矩阵,那做一下这个吧.在之前的螺旋矩阵的main函数基础上,写个函数接口就行了,这一次做的很快,但是这个矩阵感觉比螺旋 ...
- [问题2015S07] 复旦高等代数 II(14级)每周一题(第八教学周)
[问题2015S07] 设 \(A\) 为 \(n\) 阶复方阵, 证明: 存在 \(n\) 阶非异复对称阵 \(S\), 使得 \(A'=S^{-1}AS\), 即 \(A\) 可通过非异复对称阵 ...
- Web页面速度测试工具
开发框架的时间,想测试单例和多例下对性能的影响,找了下没有特别简单易用的测试工具. 估摸着搞了一个小工具. 针对.net Framework的2.0,3.5,4.0版本. WebHttpTest2.0 ...
- 17.KVM安装之虚拟磁盘,安装脚本
1.创建磁盘 vm.list 指定虚拟磁盘名称和主机名 create_vm.sh #创建vm.list中的虚拟磁盘,并指定大小100G #!/bin/bash VM_DIR="/opt ...
- springMVC简单示例
1.新建web工程 2.引入springframework架包 3.配置文件 web.xml <?xml version="1.0" encoding="UTF-8 ...
- Ubuntu快捷键
https://linux.cn/article-3025-1.html 超级键操作 1.超级键(Win键)–打开dash. 2.长按超级键– 启动Launcher.并快捷键列表. 3.按住超级键,再 ...
- POM.xml 标签详解
pom作为项目对象模型.通过xml表示maven项目,使用pom.xml来实现.主要描述了项目:包括配置文件:开发者需要遵循的规则,缺陷管理系统,组织和licenses,项目的url,项目的依赖性,以 ...
- 查看rpm和war包内容
解压rpm包的内容:(没有安装,就像解压tgz包一样rpm包)rpm2cpio *.rpm | cpio -div 解压war包的内容: jar -xvf project.war 解压到当前目录
- wifidog 配置中文说明
#网关IDGatewayID default#外部网卡ExternalInterface eth0#无线网卡GatewayInterface eth0#无线IPGatewayAddress 192.1 ...