貝爾實驗室九號計畫
貝爾實驗室九號計畫(英語:Plan 9 from Bell Labs,常简称为Plan 9)是一个分布式操作系统,由贝尔实验室的计算科学研究中心在1980年代中期至2002年开发,以作为UNIX的后继者。它现在仍然被操作系统的研究者和爱好者开发使用。[4][5] Plan 9的特色功能有:将所有本地和远程资源以文件形式组织的9P协议,union mounts,改进的进程文件系统以及原生的Unicode支持。在Plan 9中,所有的系统接口(如网络和用户界面接口),都是作为文件系统的一部分呈现,而不像其他操作系统上一样拥有自己独立的接口。 Plan 9得名于艾德·伍德1959年拍摄的B级科幻电影外太空九号计划 [6],而它的标志格伦达来自同一导演拍摄的另一部电影忽男忽女。 2021年3月21日,目前所屬諾基亞旗下的貝爾實驗室,宣布將一切知識產權以及未來開發工作轉交給新成立的九號計畫基金會(Plan 9 Foundation)。[7] 歷史
九號計畫在貝爾實驗室中取代UNIX成為組織中主要的研究開發平台。與原先的UNIX模型相較,其發展出來的數種改變改善了系統的使用及程式開發,尤其是在分散式多使用者環境中。起先在1980年中期,九號計畫只是貝爾實驗室的內部計劃。到了1992年,貝爾實驗室提供第一個公開版本提供給學院使用。在1995年,商業化的第二版釋出提供一般大眾使用。1990年代後期,朗訊科技繼承了貝爾實驗室後,對商業化九號計畫失去了興趣。到了2000年釋出了非商業化的第三版,採用開放原始碼授權。而2002年的第四版更採用自由軟體授權。 一個包括現任和前任貝爾實驗室成員與麻省理工學院成員參與的使用者與開發人員社群,仍每天以光碟影像檔的形式持續提供每日更新釋出的檔案。貝爾實驗室也仍舊承續九號計畫的開發[10]。開發中的原始碼檔案可以透過9P及HTTP協定加以存取並用於既有安裝檔案的更新[11]。除了光碟映像檔中作業系統所包含的官方套件以外,貝爾實驗室也架設了一個空間供外部開發的應用程式與工具存放。 概觀貝爾實驗室九號計畫主要是由貝爾實驗室計算科學研究中心(Computing Sciences Research Center)的成員所開發,該團體也曾開發UNIX及C語言[12]。九號計畫團隊原先由羅勃·派克、肯·汤普逊、Dave Presotto及Phil Winterbottom所帶領,及計算科學研究中心主管丹尼斯·里奇所支持。在多年的開發過程中,有許多開發人員對這項專案做出了不小的貢獻,如布萊恩·柯林漢、Tom Duff、道格拉斯·麥克羅伊、比雅尼·史特勞斯特魯普、Bruce Ellis、Steve Simon等人[13]。 九號計畫是針對現代分散式環境而從開始就設計成一種網路作業系統並加以開發。不同於UNIX是在設計後才增加圖形化使用者介面的功能,九號計劃打一開始就內建了。雖然仍未成為大受歡迎的UNIX衍生系統,但仍有持續成長的開發者社群。 九號計畫具備了分散式架構,它可以被安裝並使用於單一自含系統上,也有能力把作業系統的功能套件散佈於分散的硬體平台上。在標準的九號計畫安裝系統中,使用者會以一個輕量化的終端機執行Rio 圖形化使用者介面透過網路連接到CPU伺服器來處理計算密集型(computation-intensive)的程序,並藉由額外的檔案伺服器及歸檔儲存系統提供長期的資料儲存。現有的桌上型電腦亦可以在內部使用多個虛擬機器重現此種架構。 設計概念九號計畫的設計者對與微核心類似的目標感興趣,但是以不同的架構與設計細節來達成這些目標。九號計畫的設計目標如下:
一體化的輸入/輸出模型在UNIX之前,多數的作業系統都各自有不同的機制來存取不同類型的裝置。舉例來說,存取磁碟的API與自序列埠傳送或接收的API、又或是操作印表機所使用的API,彼此之間都有所不同。 UNIX藉由透過磁碟索引節點(disk inodes)執行所有輸入/輸出操作來嘗試移除這些差異。每個裝置都被要求必須要支援帶有意義的讀取和寫入操作用以作為控制的手段。這也允許使用者無須了解底層的實作細節,便能利用如cp及dd等指令從任一裝置送出資料給其他的裝置。然而在此同時,許多關鍵的概念(如控制行程的狀態)並沒有一致地對應到檔案系統上。如同柏克萊接口與X Window系統等的新功能被開發出來以後,以檔案系統之外的方式實作。新的硬體功能(如在軟體中使光碟機退片的功能)也建議採用特定硬體(hardware-specific)控制的機制,如使用ioctl系統呼叫等。 九號計畫不採用這些不同的實作,而且回歸到以檔案系統為中心(file system-centric)的系統觀點。無論是網路或者使用者介面、甚至是視窗本身,所有可用資源對於每個九號計畫的程式來說,都是階層式檔案系統的一部份,而非特定的介面[10]。 檔案系統、檔案與名稱九號計畫擴充系統到超越檔案的概念,來到了「名稱」的層次。無論是電腦的檔案、顯示器、使用者或電腦本身,都是一個獨一無二的路徑名稱。這些都是透過既有的UNIX標準來處理,並擴充至所有的物件皆可以用一致的方式來命名及定址。這跟全球資訊網所使用的URI的概念很相似。在UNIX中,像印表機這樣的裝置會透過軟體轉換的方式在 九號計畫的另一個創新點則是使用者可以對相同的「真實世界」物件各自分別取不同的名稱。每個使用者都可以藉由在他們的命名空間中收集各式各樣不同的物件來創造屬於他們自己的個人化環境。UNIX也有類似的觀念,使用者可以複製其他使用者來獲取權限。但是九號計畫則把這種作法擴充到所有的物件,使用者可以輕易地產生自身的「複製品」,加以修改,就算移除這些複製品也不會影響他們創造過的資源。 合併目錄UNIX允許從不同的資源透過「連結」或檔案系統「掛載」的觀念來建立檔案系統。這些功能會屏蔽掉原先的目錄,如果有人在名為「net」的目錄下掛載了新的檔案系統,會導致無法存取先前可以在「net」目錄下存取的內容,除非取消掛載的操作。 九號計畫則採用合併目錄的想法,從不同媒體或網路資源合併的目錄會以透明(transparently)的方式繫結。舉例來說,可以把別台電腦的 現今有許多Linux發行版的Live CD,一定程度上的以合併掛載的方式實做了這個功能。 /proc列出所有執行中行程的 使用者也可以從其他的機器上將 /net九號計畫並沒有使用任何系統呼叫來處理眾多的通訊協定或裝置驅動程式的介面。舉例來說, 以下是在 這讓程式設計師很容易就可以在採用檔案系統的標準命名格式、存取控制、安全機制的情況下,從不同的系統上使用不同的語言合併「物件」或檔案系統,大大增加了使用上的透明度。 這也跟BSD的 網路與分散式運算九號計畫雖然是基於UNIX,但是設計上則是想達成運算系統核心功能間彼此溝通的觀念。所有系統資源都被當成檔案般地命名及存取,並提供可根據在特定機器上各個程式設定的多種分散式系統視圖(view)。這種讓伺服器以類似傳統檔案的方式,把任何資訊都呈現給使用者及應用程式的實作方式,增進了應用程式設計上的一般化與模組化的能力。 九號計畫支援網路通透性的關鍵在於採用一種新的底層網路協定9P。9P協定實作了連結到命名網路物件並以類檔案(file-like)系統呈現的方式。藉由快速的位元導向(而非區塊導向),分散式檔案系統可以把任何物件視覺化的呈現,而非透過遠端機器上的一個NFS伺服器再加以呈現。這個協定可以用來跟行程、程式、資料、以及包含使用者介面及網路以及彼此之間進行通訊。在第四版中,這個協定作了一些修改並且更名為9P2000。 Unicode九號計畫的系統採用Unicode作為編碼機制。九號計畫中運用由Ken Thompson提出重大修改的UTF-8作為整個系統中的原生編碼,並在1992年將整個系統提供作一般使用[14]。不過九號計畫僅支援Unicode中基本多文种平面中有定義的部份。 實作除了x86架構下有可安裝的實行環境之外、九號計畫也移植到MIPS、DEC Alpha、SPARC、PowerPC、ARM及其他硬體平台上。系統以衍生自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中則推測九號計畫缺乏被接受度。
對於九號計畫的評論像是在作業系統設計中把九號計畫列為糟糕的更好的典範,其他常見的評論則有九號計畫作業系統中缺乏「優雅」(polish)及開發環境[17]、九號計畫中達到商業化程度的軟體支援量不足[18]。 九號計畫的支持者和開發人員聲稱阻礙其發展的問題已被解決,原先作為分散式系統、開發環境、研究平台的目標也都已經達成,而且也慢慢地開始有人採用。可透過Inferno的托管能力將九號計畫的技術帶給其他系統,形成異構網格運算中的一部份[19][20][21][22]。 授權完整的原始碼 (页面存档备份,存于互联网档案馆)可以免費的在朗訊公共許可證1.02版的授權之下取得,而且被開放原始碼促進會認為是開放原始碼軟體及自由軟體基金會認為是自由軟體。它雖然有通過Debian自由軟體指導方針,不過不相容於GNU通用公共許可證。 2021年3月23日之后,所有版本以MIT License授权。[23] 參照九號計畫標準程式庫
實作介面
影響
參見
參考文獻
外部連結貝爾實驗室文件其他原生及虛擬機器原生虛擬其他資源
|