操作系统体系结构的研究分析.pdf
《操作系统体系结构的研究分析.pdf》由会员分享,可在线阅读,更多相关《操作系统体系结构的研究分析.pdf(7页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、计算机科学2 0 0 5 V 0 1 3 2 N o 9操作系统体系结构的研究分析*)石进陆音谢立(南京大学计算机科学与技术系计算机软件新技术国家重点实验室南京2 1 0 0 9 3)摘要操作系统是计算机中最基本的系统软件,它控制计算机的所有资源并提供应用程序开发的基础。本文介绍了几种主要的计算机操作系统体系结构,并分析和比较了它们的优缺点,最后还介绍了操作系统体系结构目前研究趋势。关键词操作系统,体系结构,内核R e s e a r c hO HO p e r a t i n gS y s t e mA r c h i t e c t u r e sS H IJ i nL U Y i nX
2、I E L i(S t a t eK e yL a b o r a t o r y o rN o v e lS o f t w a r eT e c h n o l o g y,D e p a r t m e n to fc o m p u t e rs c i e n c ea n dt e c h n o l o g y,N a m i n gU n i v e r s i t y,N a m i n g2 1 0 0 9 3)A b s t r a c tO p e r a t i n gs y s t e mi st h em o s te s s e n t i a ls y s t
3、 e ms o f t w a r ei nc o m p u t e r,w h i c hc o n t r o l sa l lr e s o u r c e so fc o m p u t e ra n dp r o v i d e st h ef o u n d a t i o nf o ra p p l i c a t i o n sd e v e l o p m e n t W ei n t r o d u c es o m eb a s i ca r c h i t e c t u r e so fc o m p u t e ro p e r a t i n gs y s t
4、e m,a n da n a l y z et h e i rr e l a t i v em e r i t s T h ep r o g r e s sd i r e c t i o no fo p e r a t i n gs y s t e ma r c h i t e c t u r er e s e a r c hi sd e s c r i b e di nt h el a s to ft h ep a p e nK e y w o r d sO p e r a t i n gs y s t e m,A r c h i t e c t u r e,K e r n e l1引言操作
5、系统是计算机中最基本的系统软件,它控制计算机的所有资源并提供应用程序开发的基础。从不同的角度来看,操作系统所表现的形式是不同的。从用户的角度看,操作系统所体现是它所提供的各式各样的服务;从程序员的角度来看,操作系统体现的是提供给用户的界面和接口;而从设计人员的角度来看,操作系统又是一大堆模块和它们之间的相互联系,即操作系统的体系结构 1 。实际上,建造一个新的操作系统最主要的任务就是体系结构的设计。随着计算机体系结构和计算模式的发展,它从最初的简单控制循环体的形式发展到复杂的分布式操作系统,用户对操作系统的需求也呈现出了多样化的趋势,现代操作系统已经发展成了最为复杂、最为庞大的软件系统之一。然
6、而软件工程的研究与实践告诉我们,研究软件系统的体系结构对于处理软件系统的复杂性有着重要的意义。操作系统从诞生之初到现在,已经有了几十年的历史,其间提出了多种操作系统体系结构。本文将依次介绍其中最具有代表性的操作系统结构,分析比较它们的优、缺点,并介绍了其研究趋势。2 主要操作系统体系结构分析2 1 简单结构系统简单结构系统主要产生在操作系统发展初期,由于受硬件平台的性能、软件工程技术水平的限制,当时的操作系统结构体现出来的实际上是没有清晰的整体结构,整个系统呈现一种“大杂烩”的局面。操作系统内核程序和用户应用程序混杂在一起,在同一个地址空间上运行(如图1)。图1 简单结构操作系统示意图这些操作
7、系统往往是由很小的实验性的项目逐步演化而来的,因而宏观结构非常模糊,使用了早期的多入口、多出口、一个模块完成多个功能的粗模块方法,模块之间可以相互任意调用,整个系统实际上是一堆过程的集合。M D()s 就是一个很好的例子,在设计之初,M D 0 s 的设计目标是在比较有限的硬件资源上运行比较有限的应用程序,开发人员很可能都没有预料到它日后在市场上的巨大成功,因而模块之间的相对独立性几乎被忽略 2 。相似的情况也发生在U N I X 家族之中。早期的U N 因为受限于当时的硬件能力,也一直都是采用非常简单的、模糊的结构 3 。随着U N I X的不断发展这样结构也很快成为了U N I X 演进的
8、瓶颈。其他采用这种简单结构的操作系统还包括P a l m O S5 及以前的P a l m O S【:钆M a cO S9 及以前的M a cO S c 5 1、W i n d o w sM E 及以前版本的W i n d o w s 操作系统 2 6 ,以及很多其他的小型的嵌人式操作系统 7 。2 2 单体内核结构系统*)本课题得到江苏省科技攻关项目B E 2 0 0 2 0 4 5 资助。石进博j 研究生,研究方向为信息系统安全、安全操作系统。陆音博士研究生,研究方向信息系统安全。谢立教授,博士生导师,研究领域为信息系统安全,分布式操作系统等。2 3 4 万方数据随着硬件平台的性能逐渐提高
9、,硬件的数量和种类也越来越多,操作系统也越来越复杂,它提供的功能也越来越多,逐渐地单体内核结构的操作系统开始出现,它通过一种称之为系统调用的A P I 机制对外层的用户程序提供服务。通常情况下,单体结构内核提供的主要功能有:文件管理、设备驱动、内存管理、C P U 调度以及网络协议处理等。为了更好地控制内核的复杂度,内核的开发人员开始借助于软件工程领域中比较成熟的模块化方法,按照操作系统的功能将单体结构内核进行结构化。这样,整个内核按照功能的不同,被结构化成若干模块:文件管理模块、设备驱动模块、内存管理模块、C P U 调度模块以及网络协议处理等模块。这些模块共享内核的地址空间,它们之间定义了
10、很好的以函数调用的形式提供的通讯接口,模块之间的通讯只能借助于这一接口进行。模块内部的变量只能在模块内部访问。模块化的方法使得某一模块的变化被局部化,只要模块间的通讯接口没有发生改变,一个模块局部的改变不会影响其它的模块,不像简单结构操作系统,一个过程发生变化,调用该过程的其它过程均要做出相应的变化。这种模块化的方法使得操作系统的内核具有易维护、易扩充的特点。A p a c h eM o z i l l aE m a c s、型严半产日广I1|IK e r n e l-,-JC P US c h e d u l i n gI n t e r p r o c e s sC c a m m i c
11、 a t i o n、局_ 等芝孓一?,图2 单体结构操作系统示意图应用软件之下的操作系统核心中:F“,各个模块的活动层次仍然是相同的(如图2)。其模块化的过程是纯粹从软件工程的角度进行的。由于单体内核操作系统的简单性,在以集中式计算为主要计算模式的主机时代,单体结构内核得到了广泛的应用。著名的U N I X 操作系统 3 就是那个时代的典型代表。直到今天,仍然有很多著名的操作系统采用的是单体内核,如L i n u x E8|,M a c0 SX C 引,W i n d o w sN T X p c l 0 3,B S D 1 1 等系统。2 3 层次式结构为了消除简单结构系统和单体内核结构系
12、统的许多弊病,切实实现操作系统的设计目标,必须减少各模块之间的紧密依赖、相互调用的关系,特别是消除循环调用现象,实现有序调用。层次式结构正是从这一点出发的。在分层结构的操作系统内核中,系统由若干个层次构成,每一层都构建在其下的一层之上。最底层就是硬件裸机,最高层则是应用程序。在设计分层结构的操作系统内核时,每一层的构造采用的是类似于抽象数据类型的设计方法。每一层中包含了若干的数据和操作,所有的层次内的数据以及部分层次内的操作对其它层是不可见的,也即其它层不能对这些数据和操作进行访问。每一层均公布了一定的操作接口以供其它层调用,这些接口也是外层访问该层唯一的途径。层与层之间的调用关系是严格遵守调
13、用规则。每一层只能够访问位于其下层所提供的服务,利用它的下层提供的服务来实现本层的功能并为其上的层提供服务,每一层不能够访问位予其上的层次所提供的服务。理想的层次式结构不仅之间是单向依赖的,而且每一层之间也是相互独立的,即它们仅调用低层模块,各模块之间没有调用关系,这种结构称为全序的(图3 A)1 2 1。1 9 6 8 年蹦k s t r a 和他的学生在荷兰的E i m d h o v e n 技术学院所开发的T H E 系统,就是一个全序的层次式结构的操作系统。但是在实际实现特别是大型操作系统,建成全序层次是很困难的,无法完全消除循环调用现象。各层之间是单向依赖,但是在某些层内,允许各模
14、块之间有循环关系,这种层次式结构称为半虽然内核被模块化,但所有的模块仍然运行于硬件之上、序的(图3 B),多伦多大学的文J E ”3 操作系统是半序结构的。l _ p a c I l e|II I i l l aI 嘶l、7 夕一T 一夕1 r 一厂一-_ 一砼:圭:二乏;二=一、L 竺#苎一!罕口 兰 f T、T1I 一一tI F i l e 八;,t I 也#、I 牵l 岑量步篆r同焉孟i 五司l 啪玎h 唧一tI 眄忑蒜i、。一,。一一7。,Y 一。f 一芒麦一苣荔“萎示薹j 芒妾一A 全序一:;:芝!,:!:!;!、s 乏。!;j!君一J与乙睾又艺千型、乙¥一一:I 喜:、L i b
15、i f i l e L i b t h r e a d 隹扫L i b I o、ll、:匣聂舅亘j 时亘奏H I 0 一&一t j:阿墨H 号冬!太哕毒寸7 壬【差叵商一高一、图3 层次式结构示意图2 4 微内核结构微内核结构又称客户机服务器结构。现代操作系统的一个发展趋势是,进一步发展将代码移到更高层次的思想,即尽可能多地从操作系统中去掉东西,只留下一个很小的内核。通常采用的方法是,由用户进程来实现大多数操作系统的功能。为j,得到某项服务,比如读一文件块,用户进程(即客户B 半序机进程)把请求发给服务器进程,随后服务器进程完成这个操作并返送回答信息。如图4 所示,操作系统内核的全部工作是处理
16、客户机与服务器之间的通信。操作系统被分成多个部分,每个部分仅仅处理一个方面的功能,如文件服务、进程服务、终端服务或存储器服务等。这样每个部分更小,更易于管理。而且所有2 3 5 万方数据的服务都以用户进程的形式运行,它们不在核心态下运行,所以不直接访问硬件。这样处理的结果是:如果文件服务器中发生错误,则文件服务器有可能崩溃,但是整个系统不会导致崩溃。fN e t w o r k i n g、蘸:船嘲(F i l e 娜t e m,7|?f,八【锹托?罗曲带怒。二名se一蛔户啪心1严j,|7lC P UI M e m o r yN e t w o r kI D i s xi o图4 微内核结构示
17、意图图4 中的内核只处理客户机与服务器之间的消息传递,实际的系统与图中的情形不完全符合。一些操作系统的功能(比如在物理I 0 设备寄存器中写人命令字)单靠用户空间的程序是很难完成的。有两种解决这个问题的方法:一个方法是建立一些运行于核心态的关键的服务进程(例如,I 0 设备驱动程序),它们拥有访问所有硬件的绝对权力,但它们仍然使用通常的消息机制与其他的进程通信。另一个方法是,在内核建立起最小的机制,从而把策略留给在用户空间的服务进程。例如,内核可能会向某一个磁盘上的I 0 寄存器,用来启动一个读盘操作。在此例子,内核甚至不对该消息的内容进行合法性检查,而只是把它们机械地拷贝进磁盘寄存器。微内核
18、操作系统的代表有:M a c h 1 4 ,C h o r u s 1 5 ,Q N X 1 6 ,G N U H u r d 1 7 ,L 4 1 8 等。2 5 外核结构 1 9 外核结构是操作系统设计中为了获得性能和灵活性的一个极端。它试图将操作系统接口降低到硬件层,从内核中去除所有传统操作系统提供的抽象,并且将重点放在以可获得的硬件资源的复用上。在外核结构中,内核只负责简单的申请、释放并复用硬件资源,而将内存映射、I 0 和复杂的线程包等所有在传统操作系统内核中提供的抽象都转移到用户空间运行(图5)。图5 外核结构示意图在外核结构中,内核负责三个重要的任务:(1)跟踪资源的所有权,(2
19、)通过保护所有应用或绑定点来实现访问控制从而确保系统安全性没有受到侵犯,和(3)撤回对资源的访问。2 3 6 在核外,所有在传统操作系统内核中的抽象都由用户应用以库的形式提供,如应用级虚拟内存、I P C 等,用户程序通过调用库的形式实现对硬件资源的直接访问。外核结构的操作系统一个典型就是M I T 的E x ok e r n e l ”。3 操作系统体系结构分析与比较简单结构的操作系统的优点是结构紧凑、组合方便、对不同的用户环境和要求可以进行裁剪,而且具有较好的灵活性;而且由于各过程间可以直接调用或引用,从而系统效率高。它的主要缺点是系统的结构不清晰,由于各过程之间无规律地相互调用,相互依赖
20、,构成了一个复杂的网络,其调用关系是一个相当复杂的有向图,由于整体性太强,人们难于对结构作出清晰的判断;它的各过程间紧密耦合,对任何情况的修改很可能需要连锁式修改有关很多模块,因此其适应性差,难于对系统进行修改和维护;另外其系统的可靠性低,一方面是因为很难保证这种复杂关系的模块设计的正确性,另一方面是因为各模块之间的网状调用关系会造成死锁;从信息隐藏的角度看,它没有任何隐藏,每一个过程对任何其它过程都可见,因此其安全性也较差。单体内核结构操作系统的优点是结构简单,容易理鳃;由于其大部分操作系统模块均在内核中,因此性能较高;并且由于在应用之间的实行的保护机制,因此安全性也较高。缺点是核心组件没有
21、保护;且核心间模块的关系复杂,也就是说实际上整体的结构仍然是复杂的,导致其可扩展性差,灵活性也不够高。用分层的方法来构造操作系统的好处主要是易于系统调试和验证。第一层是直接构建在硬件裸机之上的,在假设硬件裸机在无误的情况下,可以调试第一层,以确保它的正确性。在得到第一层正确性的保证的情况下,可以调试第二层,以确保第二层的正确性,利用这种层层演进的方法可以验证整个系统的正确性。如果某一个错误在调试某一层的时候被发现,可以确定该错误一定是该层造成的,因为其下的层次已经被调试过,并得到其正确性的保证。通过分层的方法可以简化系统的调试与验证。层次式结构的缺点是困难的系统设计。它的每一层需要严格而仔细的
22、设计,因为每一层只能访问其下层提供的服务来实现自己的功能。在操作系统的内核中,功能模块之间的调用关系是网状的,很难模型化为层次结构,有时为了层次化的结构不得不把更多的功能模块合为一个层次,或者强行将各个模块层次化,这又不可避免的带来了系统性能的下降。由于上述的困难,分层结构的操作系统的研究与开发主要集中于研究领域,但是商业的一些知名的操作系统在设计的时候也大量借鉴了分层的思想。用微内核结构构造操作系统可以带来较高的灵活性、扩展性以及可靠性,同时又是控制系统的复杂度的有效方法,因此微内核结构得到了广泛的关注,很多著名的商用操作系统都是基于微内核结构构造的。在研究领域,微内核结构一直是操作系统界的
23、研究热点之一。但微内核结构的缺点也是很明显的,因为每次应用程序对服务器的调用都要经过两次核心态和用户态的切换,因为效率比较低。微内核结构的另一个优点是,它适用于分布式系统,如果客户机能通过消息传递和服务器通信,那么客户机不需知道这条消息是在本地机处理还是通过网络送给了远地上的服务器。这两种情况下,客户机对它们的处理都是相同的:发一请求,收一应答。外核结构一个明显的优点是较快的运行速度,因为应用 万方数据是直接访问硬件的;另外一个优点就是可扩展性,因为对于外核结构来说,增加一个新的功能仅意味着在应用层增加一个系统库而已,对内核不需要作任何修改;还有就是灵活性,也是比较明显的,因为对于不同的应用环
24、境和应用需求,所做的修改仅是系统库的配置的不同。外核结构的缺点是安全性较低,因为大量的共享服务被放到应用层,而在应用层的共享服务的安全必须由用户来保护的,显然这就降低了操作系统的安全性。通过上文中对操作系统主要体系结构的分析,我们可以看出,各种体系结构均有其优缺点,如表l 所示。袁1 各体系结构相关特性比较表性能扩展性复杂度灵活性安全性简单结构很高很差很复杂很差很低单体内核结构高差复杂差高层次式结构很低差很简单差高微内核结构低好简单好高外核结构很快好复杂很好低计算机操作系统要实现的任务主要对计算机硬件资源进行管理并提供给应用相应的接口。操作系统要尽可能提供很高的性能,很好的扩展性,很好的灵活性
25、,很高的安全性并且结构要简单。可从上面的分析我们可以看出,没有一种体系结构能同时满足上述要求,而只能在某些方面能够满足,也就是说目前的体系结构都是上述五个特性的折衷。比如,层次式结构和微内核结构的操作系统的结构都是比较简单的,但是这却牺牲了系统的性能,因为层次式结构在分层调用和微内核结构在通信时会浪费一些时间。而外核结构和简单结构由于应用能够直接访问硬件设备,使得性能大大提高,可是也因此而安全性降低了,同时系统的结构也很复杂。4 操作系统体系结构研究趋势目前,有关操作系统体系结构的研究,主要集中在三个方面:1)将软件方法学中的一些新方法使用到操作系统的设计中,比如使用面向对象 2、面向A g
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 操作系统 体系结构 研究 分析
限制150内