贝尔实验室九号计画

贝尔实验室九号计画(英语:Plan 9 from Bell Labs,常简称为Plan 9)是一个分布式操作系统,由贝尔实验室的计算科学研究中心在1980年代中期至2002年开发,以作为UNIX的后继者。它现在仍然被操作系统的研究者和爱好者开发使用。[4][5]

贝尔实验室九号计画
格伦达,九号计画的吉祥物,由Renée French英语Renée French绘制[1]
rio (视窗介面)
开发者贝尔实验室
(现已交由Plan 9 Foundation接手)
编程语言衍生自ISO/ANSI C
作业系统家族类Unix系统
运作状态支援中
源码模式自由及开源软体
首次发布1992年(仅供学院)
1995年(一般大众)
当前版本Fourth Edition (2015年1月10日,​9年前​(2015-01-10)[2]
支援平台x86MIPSDEC AlphaSPARCPowerPCARM
内核类别单核心[3]
默认用户界面rio / rc
许可证MIT
官方网站https://p9f.org/
https://plan9foundation.org/

Plan 9的特色功能有:将所有本地和远程资源以文件形式组织的9P协议,union mounts,改进的进程文件系统以及原生的Unicode支持。在Plan 9中,所有的系统接口(如网络和用户界面接口),都是作为文件系统的一部分呈现,而不像其他操作系统上一样拥有自己独立的接口。

Plan 9得名于艾德·伍德1959年拍摄的B级科幻电影外太空九号计划 [6],而它的标志格伦达来自同一导演拍摄的另一部电影忽男忽女

2021年3月21日,目前所属诺基亚旗下的贝尔实验室,宣布将一切知识产权以及未来开发工作转交给新成立的九号计画基金会(Plan 9 Foundation)。[7]

历史 编辑

日期 发行版本 注释
1992 Plan 9第一版 贝尔实验室向各大学发布
1995 Plan 9第二版 贝尔实验室发布,允许非商业使用[8]
2000 Plan 9第三版(巴西 朗讯科技在开源许可下发布,允许非商业使用
2002 Plan 9第四版 朗讯科技在自由软件许可MIT下发布[9]

九号计画在贝尔实验室中取代UNIX成为组织中主要的研究开发平台。与原先的UNIX模型相较,其发展出来的数种改变改善了系统的使用及程式开发,尤其是在分散式多使用者环境中。起先在1980年中期,九号计画只是贝尔实验室的内部计划。到了1992年,贝尔实验室提供第一个公开版本提供给学院使用。在1995年,商业化的第二版释出提供一般大众使用。1990年代后期,朗讯科技继承了贝尔实验室后,对商业化九号计画失去了兴趣。到了2000年释出了非商业化的第三版,采用开放原始码授权。而2002年的第四版更采用自由软体授权。

一个包括现任和前任贝尔实验室成员与麻省理工学院成员参与的使用者与开发人员社群,仍每天以光碟影像档的形式持续提供每日更新释出的档案。贝尔实验室也仍旧承续九号计画的开发[10]。开发中的原始码档案可以透过9PHTTP协定加以存取并用于既有安装档案的更新[11]。除了光碟映像档中作业系统所包含的官方套件以外,贝尔实验室也架设了一个空间供外部开发的应用程式与工具存放。

概观 编辑

贝尔实验室九号计画主要是由贝尔实验室计算科学研究中心(Computing Sciences Research Center)的成员所开发,该团体也曾开发UNIXC语言[12]。九号计画团队原先由罗勃·派克肯·汤普逊Dave PresottoPhil Winterbottom所带领,及计算科学研究中心主管丹尼斯·里奇所支持。在多年的开发过程中,有许多开发人员对这项专案做出了不小的贡献,如布莱恩·柯林汉Tom Duff道格拉斯·麦克罗伊比雅尼·史特劳斯特鲁普Bruce EllisSteve Simon等人[13]

九号计画是针对现代分散式环境而从开始就设计成一种网路作业系统并加以开发。不同于UNIX是在设计后才增加图形化使用者介面的功能,九号计划打一开始就内建了。虽然仍未成为大受欢迎的UNIX衍生系统,但仍有持续成长的开发者社群。

九号计画具备了分散式架构,它可以被安装并使用于单一自含系统上,也有能力把作业系统的功能套件散布于分散的硬体平台上。在标准的九号计画安装系统中,使用者会以一个轻量化的终端机执行Rio 图形化使用者介面透过网路连接到CPU伺服器来处理计算密集型(computation-intensive)的程序,并借由额外的档案伺服器及归档储存系统提供长期的资料储存。现有的桌上型电脑亦可以在内部使用多个虚拟机器重现此种架构。

设计概念 编辑

九号计画的设计者对与微核心类似的目标感兴趣,但是以不同的架构与设计细节来达成这些目标。九号计画的设计目标如下:

  • 以档案系统为基础的装置:把所有的资源都列在阶层式档案系统中,以节点(Node)表示。
  • 命名空间:从应用程式的观点来看,网路是种单一且清楚的命名空间,能展现阶层式档案系统,也能代表近端或远端实体分离的资源。每个程序的命名空间皆能独立建置,使用者也能同时使用采用各式命名空间的应用程式。
  • 标准通讯协定:采用名为9P的标准协定,用来存取近端或远端的所有资源。

一体化的输入/输出模型 编辑

在UNIX之前,多数的作业系统都各自有不同的机制来存取不同类型的装置。举例来说,存取磁碟API与自序列埠传送或接收的API、又或是操作印表机所使用的API,彼此之间都有所不同。

UNIX借由透过磁碟索引节点(disk inodes)执行所有输入/输出操作来尝试移除这些差异。每个装置都被要求必须要支援带有意义的读取写入操作用以作为控制的手段。这也允许使用者无须了解底层的实作细节,便能利用如cpdd等指令从任一装置送出资料给其他的装置。然而在此同时,许多关键的概念(如控制行程的状态)并没有一致地对应到档案系统上。如同柏克莱接口X Window系统等的新功能被开发出来以后,以档案系统之外的方式实作。新的硬体功能(如在软体中使光碟机退片的功能)也建议采用特定硬体(hardware-specific)控制的机制,如使用ioctl系统呼叫等。

九号计画不采用这些不同的实作,而且回归到以档案系统为中心(file system-centric)的系统观点。无论是网路或者使用者介面、甚至是视窗本身,所有可用资源对于每个九号计画的程式来说,都是阶层式档案系统的一部份,而非特定的介面[10]

档案系统、档案与名称 编辑

九号计画扩充系统到超越档案的概念,来到了“名称”的层次。无论是电脑的档案显示器使用者电脑本身,都是一个独一无二的路径名称。这些都是透过既有的UNIX标准来处理,并扩充至所有的物件皆可以用一致的方式来命名及定址。这跟全球资讯网所使用的URI的概念很相似。在UNIX中,像印表机这样的装置会透过软体转换的方式在/dev以名称代表,但这种定址方式只对实体连接到硬体上的装置有效,并不能套用到网路装置上。在九号计画系统中,所有的印表机都会以档案的方式呈现,而且可以透过网路被任何工作站存取。

九号计画的另一个创新点则是使用者可以对相同的“真实世界”物件各自分别取不同的名称。每个使用者都可以借由在他们的命名空间中收集各式各样不同的物件来创造属于他们自己的个人化环境。UNIX也有类似的观念,使用者可以复制其他使用者来获取权限。但是九号计画则把这种作法扩充到所有的物件,使用者可以轻易地产生自身的“复制品”,加以修改,就算移除这些复制品也不会影响他们创造过的资源。

合并目录 编辑

UNIX允许从不同的资源透过“连结”或档案系统“挂载”的观念来建立档案系统。这些功能会屏蔽掉原先的目录,如果有人在名为“net”的目录下挂载了新的档案系统,会导致无法存取先前可以在“net”目录下存取的内容,除非取消挂载的操作。

九号计画则采用合并目录的想法,从不同媒体或网路资源合并的目录会以透明(transparently)的方式系结。举例来说,可以把别台电脑的/bin(应用程式)目录跟本机端系结,接下来这个目录就会同时有本地端以及远端的应用程式在里面,使用者可以无障碍的存取近端或是远端的程式。使用相同系统的情况下,九号计画所控制的外部装置与资源可以系结到/dev目录下,这可以让装置不需要任何额外的程式,就可以透过网路进行分享。

现今有许多Linux发行版Live CD,一定程度上的以合并挂载的方式实做了这个功能。

/proc 编辑

列出所有执行中行程/proc目录,描绘出这些功能是如何在共同运作时能够带来更好的整体结果。九号计画特别的"档案系统"也为Linux及其他之后的作业系统所采用。不同于其他核心资源的是,行程以/proc目录下的命名物件(内含资讯与控制档案的子目录)的形式表现,并给予使用者一组动态的输入/输出通道来对行程传送指令及读取资料。使用者无须使用受限的系统呼叫来与编译过的程式核心互动,相反的,它可以使用如ls以及cat等指令来搜寻、查询、以及操作行程。

使用者也可以从其他的机器上将/proc目录(以及任何其他特定的档案系统)挂载到自己的命名空间中,就如同这些程序是在本机端一般地与它们互动。结果就是利用个别的机器架构出一套分散式运算环境,这些机器可能是使用者桌上的终端机、储存长期资料的档案伺服器、提供较快CPU及运算能力、使用者稽核、闸道器等服务之其他伺服器,全部都采用为大多数电脑使用者所熟悉的既有的阶层式目录/命名系统。使用者可以借由终端机来收集档案伺服器、伺服器上所运行的应用程式、网路上的印表机等设备,系结进自己的命名空间进而"建构"出一套系统。

/net 编辑

九号计画并没有使用任何系统呼叫来处理众多的通讯协定或装置驱动程式的介面。举例来说,/net目录下包含了所有TCP/IPAPI,并可借由使用脚本语言命令列介面的工具来撰写可以控制档案对连线进行写入或读取的程式。底下的子目录如/net/tcp/net/udp等目录用来对应各种协定的介面。使用者可以借由挂载一台具有公开(public)IP位址的外部机器的/net目录,来让使用9P网路协定的内部网路私有(private)IP位址,能透过该外部机器进行连线的方式,进而达到实做NAT的效果。又或者使用者可以借由挂载远端闸道器的/net目录,在公开网路上使用加密(secured)的9P协定达成实做VPN的效果。

以下是在/net目录中采用合并(或称堆叠(stack))目录的例子:就像物件导向程式语言的继承观念一样,你可以把一个(可能是远端的)/special目录系结到其他的本地端特定目录下,增加一些控制档案以及是需要隐藏其他的档案。这个合并目录线再就像是原先目录的子物件一般,原先的功能可以仅更动一部份就好。对照到/net档案系统的情况,使用者可以借由更动或隐藏底下的/net/udp子目录,增加本地端过滤程序来达成控制或扩充UDP介面的功能,而不会更动到原本正在运行的(可能是远端机器上的)/net/tcp子目录的资料。命名空间是针对每个行程来设定的,如果使用者更动对/net合并目录来一个不受信任的应用程式设定限制,就可以限制该程式存取网路的能力。

这让程式设计师很容易就可以在采用档案系统的标准命名格式、存取控制、安全机制的情况下,从不同的系统上使用不同的语言合并“物件”或档案系统,大大增加了使用上的透明度。

这也跟BSDmount_portal[1] 的指令所提供的功能类似,只是挂载的目录不是/net而是/p,提供的网路协定也只有/tcp而已。

网路与分散式运算 编辑

九号计画虽然是基于UNIX,但是设计上则是想达成运算系统核心功能间彼此沟通的观念。所有系统资源都被当成档案般地命名及存取,并提供可根据在特定机器上各个程式设定的多种分散式系统视图(view)。这种让伺服器以类似传统档案的方式,把任何资讯都呈现给使用者及应用程式的实作方式,增进了应用程式设计上的一般化与模组化的能力。

九号计画支援网路通透性的关键在于采用一种新的底层网路协定9P。9P协定实作了连结到命名网路物件并以类档案(file-like)系统呈现的方式。借由快速的位元导向(而非区块导向),分散式档案系统可以把任何物件视觉化的呈现,而非透过远端机器上的一个NFS伺服器再加以呈现。这个协定可以用来跟行程、程式、资料、以及包含使用者介面及网路以及彼此之间进行通讯。在第四版中,这个协定作了一些修改并且更名为9P2000。

Unicode 编辑

九号计画的系统采用Unicode作为编码机制。九号计画中运用由Ken Thompson提出重大修改的UTF-8作为整个系统中的原生编码,并在1992年将整个系统提供作一般使用[14]。不过九号计画仅支援Unicode中基本多文种平面中有定义的部份。

实作 编辑

 
用rio进行安装的GUI画面

除了x86架构下有可安装的实行环境之外、九号计画也移植到MIPSDEC AlphaSPARCPowerPCARM及其他硬体平台上。系统以衍生自ISO/ANSI C的语言所编写。部分应用程式原先以Alef撰写,但目前皆以C语言改写。九号计画支援以POSIX应用程式透过APE来模拟柏克莱接口介面。近来有一套新的应用程式linuxemu被开发用来执行Linux的程式,目前仍有许多要改进的地方。

九号计画也被用在具代表性的超级电脑上,像是IBM BG/L Supercomputer[15]以及Blue Gene

影响 编辑

UNIX其中一个中心概念是所有系统介面皆可以一组档案的形式呈现,而九号计画成功地把这个概念以现代分散式系统实作出来。九号计画的一些功能,像是Unicode中的UTF-8编码,也被其他作业系统所实作。一些类UNIX作业系统,例如Linux,也实作9P、九号计画的档案系统,以及部份实作的类rfork指令的系统呼叫。除此之外,在Plan 9 from User Space中许多九号计画所采用的应用程式及工具,例如rc shell,也被移植到UNIX以及LINUX系统上,而且还有一定程度的人气。Glendix这个专案则尝试以GNU/Linux作业系统取代九号计画,或者是说,以Linux核心来取代九号计画的核心。

然而,九号计画并未能像UNIX一样热门,变成主要只是一种研究用的工具。九号计画被评为"作用看来不过是能在作业系统研究领域产生有趣论文的装置"[16]Eric S. Raymond在他的著作The Art of Unix Programming中则推测九号计画缺乏被接受度。

"九号计画会失败单纯只是因为它的改进程度没大能取代Unix。与九号计画相较,虽然UNIX看来破破烂烂又有明显缺失,但是它还是能好好的把工作完成,这就足以保住它的地位了。这件事情给那些有雄心壮志的系统架构的一堂课是:比更佳解决方案相比之下来的最危险的敌人是那些能把事情已经做的够好的程式。"[16]

对于九号计画的评论像是在作业系统设计中把九号计画列为糟糕的更好的典范,其他常见的评论则有九号计画作业系统中缺乏“优雅”(polish)及开发环境[17]、九号计画中达到商业化程度的软体支援量不足[18]

九号计画的支持者和开发人员声称阻碍其发展的问题已被解决,原先作为分散式系统、开发环境、研究平台的目标也都已经达成,而且也慢慢地开始有人采用。可透过Inferno的托管能力将九号计画的技术带给其他系统,形成异构网格运算中的一部份[19][20][21][22]

授权 编辑

完整的原始码页面存档备份,存于互联网档案馆)可以免费的在朗讯公共许可证1.02版的授权之下取得,而且被开放原始码促进会认为是开放原始码软体及自由软体基金会认为是自由软体。它虽然有通过Debian自由软体指导方针,不过不相容于GNU通用公共许可证。 2021年3月23日之后,所有版本以MIT License授权。[23]

参照 编辑

九号计画标准程式库 编辑

实作介面 编辑

  • 9P(或Styx) - 档案系统的协定
  • rendezvous - 基础的同步机制
  • Brazil - 变成九号计画第四版的专案

影响 编辑

参见 编辑

参考文献 编辑

  1. ^ Plan 9 Foundation. Glenda, the Plan 9 Bunny. 2006 [2023-04-20]. (原始内容存档于2023-05-30). 
  2. ^ plan9checksums. Bell Labs. [2019-07-25]. (原始内容存档于2017-06-01). Sat Jan 10 04:04:55 EST 2015 ... plan9.iso.bz2 
  3. ^ Crawford, Diane. Forum. Communications of the ACM (Association for Computing Machinery (ACM)). 1999, 42 (8): 11–15. ISSN 0001-0782. doi:10.1145/310930.310939. 
  4. ^ Robertson, James. Plan 9 Forked, Continues as 9front. OSNews. 2011-07-16 [2011-12-31]. (原始内容存档于2018-11-02). 
  5. ^ 9atom. [2011-11-11]. (原始内容存档于2019-09-11). 
  6. ^ Raymond, Eric S. Plan 9: The Way the Future Was. Unix編程藝術. Addison-Wesley. 2003-09-17 [2007-05-07]. ISBN 0-13-142901-9. (原始内容存档于2007-04-16). 
  7. ^ Marcus Weldon, Former Corporate CTO and President. Plan 9 from Bell Labs in Cyberspace!. Nokia Bell Labs. [2023-04-20]. (原始内容存档于2023-06-10). 
  8. ^ Announcement of the first release to general public. [2013-03-07]. (原始内容存档于2008-07-06). 
  9. ^ /usr/web/sources/plan9/sys/src - Plan 9 from Bell Labs. 9p.io. [2022-09-15]. (原始内容存档于2022-12-02). 
  10. ^ 10.0 10.1 貝爾實驗室九號計畫. 朗讯科技. 2006 [April 27, 2006]. (原始内容存档于2006-04-28). 
  11. ^ Staying up to date. 九号计画社群. 2006 [April 27, 2006]. (原始内容存档于2006-04-17). 
  12. ^ From the inventors of UNIX system comes Plan 9 from Bell Labs. Lucent Technologies. 1995 [April 2, 2006]. (原始内容存档于2006年2月9日). 
  13. ^ McIlroy, Doug. 第二版序言(1995). 朗讯科技. 1995 [April 2, 2006]. (原始内容存档于2006-03-14). 
  14. ^ Pike, Rob. UTF-8歷史. 2003 [April 27, 2006]. (原始内容存档于2011-03-01). 
  15. ^ 九號計畫BG展示 (PDF). [2010-04-03]. (原始内容 (PDF)存档于2011-05-14). 
  16. ^ 16.0 16.1 Raymond, Eric S. Plan 9: The Way the Future Was. [March 28, 2006]. (原始内容存档于2005-08-18). 
  17. ^ Dennis Ritchie的訪談中第25條回應. [2006-09-09]. (原始内容存档于2007-09-26). 
  18. ^ Dennis Ritchie的訪談中第23條回應. [2006-09-10]. (原始内容存档于2007-09-26). 
  19. ^ 9grid (九號計畫wiki). 九号计画wiki. 2006 [March 28, 2006]. (原始内容存档于2006-03-14). 
  20. ^ "Press Release: Vita Nuova Supplies Inferno Grid to Evotec OAI (PDF). Vita Nuova Holdings Limted. 2004 [March 28, 2006]. (原始内容存档 (PDF)于2021-03-08). 
  21. ^ "Press Release: Rutgers University Libraries Install Inferno Data Grid" (PDF). Vita Nuova Holdings Limited. 2004 [March 28, 2006]. (原始内容存档 (PDF)于2021-03-08). 
  22. ^ "Press Release: The University of York Department of Biology install Vita Nuova's Inferno Data Grid" (PDF). Vita Nuova Holdings Limited. 2004 [March 28, 2006]. (原始内容存档 (PDF)于2021-03-07). 
  23. ^ Plan 9 from Bell Labs. [2021-03-25]. (原始内容存档于2021-03-24). 

外部链接 编辑

贝尔实验室 编辑

文件 编辑

其他原生及虚拟机器 编辑

原生 编辑

虚拟 编辑

其他资源 编辑