亚洲成精品动漫久久精久,九九在线精品视频播放,黄色成人免费观看,三级成人影院,久碰久,四虎成人欧美精品在永久在线

掃一掃
關注微信公眾號

NetWare與UNIX的互聯方法與實現
2007-09-14   wudidong

異型網絡之間的互聯是當今計算機網絡技術發展的熱點問題之一。隨著計算機技術的深入發展與網絡的不斷普及,異型機與異型網絡的互相連接、互相共享資源已經成為人們需要迫切解決的問題了。現在廣泛流行的網絡操作系統netware與同樣為人們所喜愛的unix系統之間的互聯問題正是在這種背景下提出來的。由于novell公司已經成功地使netware支持tcp/ip協議,而unix的聯網正是建立在tcp/ip 協議之上的,所以一些基于tcp/ip協議的應用層協議,就自然成為解決netware與unix互聯問題的較好方法了。網絡文件系統(nfs)正是這些協議中,應用較廣、技術較為成熟的協議之一,而且現在市場上已經推出了幾十種nfs產品。

它們被廣泛地應用于netware與unix的互聯之中。本文將通過對nfs的概念和實現方法的討論,來說明netware與unix之間是如何通過nfs實現互聯的。

一、網絡文件系統概述

sun microsystems公司是以其高品質的工作站而享譽計算機界的。其工作站現已廣泛地應用于多種領域,如cad、仿真、圖形處理等。sun工作站采用的是開放式的系統結構,它們大都是基于unix操作系統之上的,并且支持tcp/ip協議作為其網絡的體系結構。也正是由于對tcp/ip協議的支持,使得sun工作站可以很方便地在ethernet上,基于tcp/ip進行通訊。

同時,又由于tcp/ip協議在網際互聯上的優越性能,使得sun工作站與其它異種機之間的通訊實現起來較為方便和容易。

為了實現網絡上的文件服務,sun公司提出了網絡文件系統(network file system, nfs)的概念。它提供了異種機、異種操作系統之間的透明在線(on-line)共享文件的手段。nfs允許用本地操作系統的i/o調用方式訪問遠地文件,并且這與文件存放的物理位置和使用何種操作系統無關。

從用戶的角度看,nfs是不可見的。用戶可以運行一獨占的程序并且可以對獨享文件進行i/o操作,而這時用戶并不清楚它們是本地的還是遠程的程序或文件。

使用nfs的好處很多。nfs允許多臺機器使用同一個數據文件,所以文件的數據對網絡上的各機器來說都是可存取的。而且nfs可以通過將大的文件存儲在一臺機器上而由大家來共享的方式,使存儲的費用明顯的降低。尤其是在數據庫應用系統中,你可以把數據文件可靠、統一地集中在一起,既可共享使用又可以進行方便的統一管理。

nfs目前已經得到開放系統組織的承認,成為今天的分布式文件系統的工業標準。nfs不僅能夠支持sun工作站之間的連接,而且能夠支持來自主要計算機廠家的產品。尤其是大多數unix操作系統,諸如sco unix,都提供了支持nfs協議的軟件,以實現unix與其它操作系統之間的通訊。

二、從網絡的體系結構來說明nfs的實現

nfs在一個操作系統中的具體形式如圖1。當一個應用程序運行時,它可以通過系統調用打開一個文件,并對其進行存取訪問。這時的文件存取系統可以接收用戶的各種請求,并且能夠自動判斷將該請求發往何處,即是本地文件系統還是nfs客戶服務部分。這種判斷是根據被請求的文件是在本地存儲介質上還是在遠程的計算機上而做出的。當一個被請求文件在遠地時,nfs客戶服務軟件利用nfs協議與遠地機器上適當的nfs服務器取得聯系,并且進行相應的請求操作。在遠地服務器對請求做出回答后,客戶服務軟件獲得結果,將它傳送給應用程序。

從程序員的角度來看,nfs協議本身并沒有提供什么特別的調用過程。一旦管理員將nfs設置完成后,程序員就可以對遠地和本地的文件進行同樣的存取操作,它們之間并無明顯的差別。

對于nfs,設計者并沒有將它設計成為解決所有文件傳輸的綜合性協議,而是將nfs的實現分成三個相對獨立的部分:nfs協議本身、遠程過程調用 (remote procedure call, rpc)機制和外部數據表示(external data representation, xdr)。如果將它們與iso/osi的推薦標準相對照的話,可以看出rpc對應于會話層,xdr對應于表示層,而nfs協議本身則對應于應用層,見圖 2。從這個體系結構可以看出,真正的nfs服務是建立在外部數據表示xdr和遠程過程調用rpc所提供的服務功能之上。

在網絡環境中,rpc為運行在不同機器、不同操作系統上的程序(過程)相互調用、傳遞參數及回送結果等提供一種規范的方法。rpc為實現網絡上的客戶/服務器模式提供了支持。比如,一個程序員可以把他的程序分解成為客戶、服務器兩部分,在客戶方面,程序員設計了一些過程,如remote,并將rpc碼插入到這些過程之中;而服務器方面,應用rpc的其他功能,實現了一些處理該種調用的過程。當一個運行中的客戶程序發出遠程調用時,rpc軟件自動對變元的值進行收集,并打成數據包(message)發往遠地服務器,啟動調用過程,最后返回結果。整個調用過程如同調用本地過程一樣。prc實際上是iso rm 會話層協議的具體實現,該機制將下層協議的細節掩蓋了起來,使程序員拋開通信協議的具體過程,就可以設計出分布式程序。

xdr是數據描述和編碼的一種標準,是表示層的具體實現。它提供了在不同體系結構的計算機之間進行數據傳輸時,數據表示的規范方法。比如,對于32- bit的整數表示方法來說,各種機器并不相同,有的將整數的主要字節放在高位地址部分,有的則剛好相反,所以在網絡上要使數據在這兩種整數表示法的機器之間進行傳送,就必須進行適當的轉換,否則數值在傳輸后會發生變化。xdr就提供了這種轉換功能。xdr采用的是iso推薦的抽象語言法表示記法1,即 asn.1,作為內部數據傳送的標準語法表示。相互通信的兩方xdr進行本地語法表示與asn.1之間的轉換與逆轉換。

rpc和xdr提供的這種網絡服務為構造nfs這樣的分布式數據處理系統奠定了基礎。由此可見,由nfs協議本身、rpc和xdr三者相結合,在 tcp/ip或udp/ip之上,實現了nfs概念的全部。它們互為基礎、互相配合,實現了基于nfs的異種設備、異種操作系統之間的透明在線共享文件的訪問功能。

三、舉例說明nfs的工作過程

為了詳細直觀地說明nfs的工作過程,我們以sun工作站上的unix操作系統為例,來說明nfs的具體工作過程,包括什么是文件階層(hierachies)、如何理解服務器和客戶、服務器如何使其它機器共享其文件以及如何對遠程機器上的文件階層進行訪問等。

1.文件階層

當通過某安裝點(mount point),從一個本地硬盤來安裝一個文件系統時,可以將整個文件系統安裝上并從它的根(root)來啟動。例如,有兩個文件系統root和usr,在不同的硬盤分區中。現在可以將usr文件系統安裝到root文件系統的/usr目錄上,并通過/usr目錄對usr分區進行訪問。

與上述原理相似,也可以將不同機器上的某個文件系統安裝到本地硬盤上,甚至可以將另外一臺機器上的文件系統中的某個目錄安裝到本地,而不必將整個文件系統都安裝過來,如圖3。

2.服務器與客戶的概念

一個文件服務器是一臺用于共享的機器,其它機器可以用它安裝(mount)文件系統。一個客戶機是一臺至少從一個文件服務器繼承了一個文件階層的機器。任何機器(除非沒有硬盤)都可以同時既作為nfs服務器,又作為nfs客戶機來使用。

3.服務器與輸出(exporting)

在一臺unix工作站上,exportfs系統程序、rpc.mountd以及nfsd守候進程(deamon)一同來控制nfs。一旦nfs文件服務器將文件階層進行輸出(export)后,此服務器上的相應目錄可由其它的機器來訪問。文件服務器上的/etc/exporfs文件列出了這些可用的目錄、可以訪問它們的客戶、以及存取權限。當你啟動exportfs程序時,/etc/rc.1oca1就會自動激活exportfs程序。該程序檢查 /etc/exportfs文件并通知服務器內核有關所輸出的每個文件階層的特權。在服務器啟動后,還可以利用export命令將一個文件階層分解成輸出和非輸出部分,或者改變一個已經輸出的文件階層的特權。

4.客戶與安裝(mounting)

客戶對文件服務器上的export目錄進行存取是通過mounting來進行的。客戶在安裝目錄時,不是復制該目錄,而是通過一系列的遠程調用來實現 mounting進程,它使用戶可以對服務器硬盤上的相應目錄進行透明存取。運行在文件服務器上的rpc以一定的格式接受信息,即xdr格式。由 rpc.mountd守候進程來處理這些信息并允許或禁止對一個文件階層進行安裝。一旦客戶將遠程目錄安裝后,客戶即可以使用“cd目錄名”命令進入相應的目錄下進行操作了,就如同操作本地硬盤一樣。客戶對有export信息的文件服務器進行定位,并在它與服務器之間建立連接,此連接進程稱為 binding, nfs的裝訂是發生在nfs安裝的時候。客戶在自舉時可以對一目錄進行安裝,也可以用mount命令來顯式地安裝,或者通過自動安裝器 (automounter)來進行。/etc/fstab文件中列出了在客戶啟動時安裝的所有文件階層。由此可見,nfs的工作是由nfs服務器和nfs 客戶進程共同實現的。只有在nfs服務器上規定了輸出的目錄或者文件系統,在nfs的客戶機上才能對其進行繼承,并通過對這些目錄或者

文件系統的安裝來實現客戶對服務器的透明訪問。

四、netware與unix工作站之間通過nfs互聯的實現

自從sun公司實現了nfs以后,它實際上已經成為unix產品的分布式文件系統。市場上有眾多的nfs產品出現,這里將以當今最流行的兩種操作系統unix、dos之間通過nfs進行透明訪問為例,來看一看nfs在互聯中的具體實現。

我們這里所要介紹的產品是netware nfs、netware nfs gateway和pc-nfs。前兩者是由novell網絡公司推出的,后者則是sun microsystems公司的產品。由于這兩個公司看待unix與dos互聯問題的角度和出發點不同,因此它們所實現的產品也就有很大的區別了。netware nfs和netware nfs gateway是novell公司從自己的netware網絡操作系統出發,基于dos的考慮所研制、開發出來的。它提供給unix工作站透明訪問netware服務器的機制以及由dos工作站通過netware服務器來共享unix資源的手段。而 pc-nfs則是sun公司從unix工作站

的觀點出發,提供給ms-dos或ms-windows用戶的、用以實現unix的nfs客戶方的軟件,使pc機用戶共享unix的資源。

1.netware nfs

netware nfs是將unix系統透明地集成到netware 3.11環境之上。它可以使得netware服務器具有nfs服務器的功能。一旦安裝了netware nfs之后,享有nfs客戶服務的unix工作站就可以與netware上的dos工作站一起共享服務器上的文件資源。它提供有 nfs、ftp等可裝載模塊(nlm)為unix客戶提供服務。netware nfs同時也在netware和unix之間提供雙向的打印網關以及與 x/window應用相交互,允許x客戶從遠程來管理netware服務器。netware nfs與其他unix系統一樣,需要使用tcp/ip作為基本的支撐協議,并籍此完成nfs上的各種功能。它的特點是:

(1)使unix用戶訪問netware

利用netware nfs,unix客戶可以訪問并從netware服務器上安裝(mount)文件系統,就如同它從一個典型的nfs服務器上所做的一樣。這使得unix用戶可以在保留了自身的操作系統優勢的同時,使用netware上的文件。

(2)將netware環境與unix環境集成

netware nfs將網絡文件系統的概念引入到netware的聯網環境中來,使得unix工作站可以與其它的netware客戶系統,例如, macintosh、dos、windows以及os/2共享文件。ftp服務可以使tcp/ip客戶系統利用ftp協議從/向netware服務器傳送文件。它提供了完整的打印集成:unix用戶可以利用netware打印機進行打印,而netware用戶也可以在tcp/ip網絡上可以訪問的打印機上進行打印。它同時使netware v 3.11成為一個功能強大的unix工作組中nfs服務器。對于用戶輸入的操作命令,可以有很短的響應時間和較高的吞吐率。

(3)提供用x/window來管理服務器

netware nfs提供xconsole應用程序來使x/window系統的用戶以及vt100/220終端用戶從遠程來管理 netware v 3.11服務器。比如,可以從一個vt100/220終端或一個unix工作站運行x/window,對netware服務器進行遠程配置和排除netware服務器的錯誤。

利用netware nfs,unix用戶在保持其原有系統的功能之外,還獲得了netware服務器優化技術所帶來的好處,如磁盤的高吞吐量、容錯技術及其安全措施等。另外,netware nfs還帶來了改進的工作組(work group)的運行效率、資源共享和高效率的網絡管理。

總之,netware nfs提供給unix工作組以高性能的nfs服務器,同時netware操作系統又帶給unix用戶以良好的時間與空間的響應,從而極大地提高了系統的性能價格比。

2.netware nfs gateway

netware nfs gateway所提供的功能與netware nfs相反,它是一個基于服務器連接的、使netware用戶可以訪問unix的方案。該產品可以讓dos和windows用戶方便地對unix上的文件系統進行訪問,就象透明訪問netware服務器一樣。

novell公司研制、開發netware nfs gateway的目的,就是要給netware用戶一種訪問unix文件的選擇。那些已經習慣于 netware環境的pc機用戶們,可以使用這種網關來共享本地或者遠程unix系統上的文件。對于這些共享文件的使用,就象操縱dos或windows 的文件一樣。通過netware nfs gateway還可以使pc用戶共享unix上價格昂貴的海量存儲資源,如cd-rom等。

netware nfs gateway的安裝與集中的管理都是由服務器來完成的。tcp/ip主機地址、unix/netware記帳信息都是在服務器上由域名字系統(domain name system, dns)和網絡信息服務(nis)統一管理起來的。這種集中管理的好處在于可以使網絡管理員從服務器上安裝和管理系統,以及獲得正確的ip地址。也正是由于nfs的文件存取是通過netware服務器來完成的,網絡用戶們因此可以得到 netware保密機制的支持。

另外,netware nfs gateway還提供了xconsole應用程序,允許x/window系統的用戶以及vt 100/220終端用戶遠程管理netware v 3.11服務器。

novell公司的這兩種nfs產品,在基于netware網絡操作系統的基礎之上,分別從兩個方面解決了netware與unix之間的文件共享、打印共享以及透明訪問等方面的問題。為局域網與廣域網的互聯提供了一種可行的解決方案。

3.pc-nfs

通過使用pc-nfs,unix工作站的硬盤可以被當作為pc機上的附加硬盤來使用。pc-nfs提供了tcp/ip的全部實現,包括ftp、telnet和其它實用程序,同時還包括將dos請求重定向至unix的能力。

pc-nfs可以支持以太網、令牌環、串行通信等通訊方式的連接。對于以太網的連接方式,可以把它安裝在其默認的一些網絡適配卡上,如3com的 etherlink系列的網卡、pc nic及ni5010等。它同時還支持ndis及odi技術,這樣就使得pc-nfs對大多數的流行網卡都可以提供支持。而且,正是由于有了對odi技術的支持,使得pc-nfs可以同時支持tcp/ip網絡和netware網絡,從而成為連接這兩種當今廣泛使用的網絡的紐帶。

在安裝了pc-nfs之后,系統通過批文件來使用net use命令,并以邏輯號,如(d:、e:)將unix的硬盤映射到pc機的本地上。pc-nfs還負責完成dos與unix的文本格式轉換,以及在ms-dos文件名和nfs文件名之間作出操作處理。

unix主機上的nfs和pc機上的pc-nfs提供了較強的聯網環境,pc從中可以利用unix工作站上的大容量存儲設備,并能在unix與dos的應用程序之間共享數據資源。

當然,在使用pc-nfs時也有一些不足。比如,該軟件為保證各機器之間的兼容性而限制了它們之間的吞吐量,這就使得它的速度不及netware快,另外,當一個配有pc-nfs的pc機與非nfs服務器使用tcp/ip軟件進行通訊時,還有可能缺乏靈活性;裝配一個pc-nfs軟件可能會占去pc機 80-90k的內存空間,這對于空間狹小的pc機來說有時會成為十分棘手的問題(在pc-nfs v 5.0中對該問題進行了改進,可以將pc-nfs的駐留程序裝入高端內存中)。

但是,pc-nfs所帶來的好處將遠遠超過這些不足,它實現了dos用戶使用unix工作站的優良性能;同時還使得unix用戶能共享擁有豐富軟件資源的 dos系統。這樣,在一定程度上滿足了雙方用戶的要求。這種將pc機集成到使用nfs的unix主機上的作法,使人們在系統的性能與機器設備的價格之間找到了平衡。

在眾多的網絡系統中將重要的桌面計算機系統:dos和unix連接在一起,共享數據與打印,相互協調地工作,這已成為人們迫切需要解決的問題。unix上基上tcp/ip協議的nfs技術為我們解決這個問題提供了一個可行的辦法。相信隨著unix與tcp/ip技術的不斷發展,nfs技術也會不斷地得到完善,將會有更好的nfs產品出現,它將在以資源共享為目的的網際互聯中發揮更大的作用。

熱詞搜索:

上一篇:Novell OES:連接NetWare和Linux的紐帶
下一篇:忘記NetWare超級用戶口令后的辦法

分享到: 收藏