■CORBA技術(shù)簡介
簡單地說,CORBA允許應(yīng)用之間相互通信,而不管它們存在于哪里以及是誰設(shè)計的。CORBA1.1于1991年由OMG發(fā)布,其中定義了接口定義語言(IDL)以及在對象請求代理(ORB)中實現(xiàn)客戶對象與服務(wù)器對象之間交互的應(yīng)用編程接口(API)。CORBA2.0于1994年發(fā)布,規(guī)定了各個供應(yīng)商之間的ORB的通信規(guī)則。
CORBA標(biāo)準(zhǔn)主要分為三個部分:接口定義語言(IDL)、對象請求代理(ORB)以及ORB之間的互操作協(xié)議IIOP。
ORB是對象之間建立Client/Server關(guān)系的中間件。使用ORB,客戶可以透明地調(diào)用一個服務(wù)對象上的方法,這個服務(wù)對象可以在本地,也可以在通過網(wǎng)絡(luò)連接的其他機器上。ORB截獲這一調(diào)用同時負(fù)責(zé)查找實現(xiàn)服務(wù)的對象并向其傳遞參數(shù)、調(diào)用方法返回最終結(jié)果。客戶并不知道服務(wù)對象位于什么地方,它的編程語言和操作系統(tǒng)是什么,也不知道不屬于對象接口的其他系統(tǒng)部分。這樣,ORB在異構(gòu)分布環(huán)境下為不同機器上的應(yīng)用提供了互操作性,并無縫地集成了多種對象系統(tǒng)。
在開發(fā)傳統(tǒng)的Client/Server應(yīng)用時,開發(fā)者使用他們自己設(shè)計的或一個公認(rèn)的標(biāo)準(zhǔn)來定義用于設(shè)備之間通信的協(xié)議。協(xié)議的定義依賴于實現(xiàn)語言、網(wǎng)絡(luò)傳輸和許多其他因素,而ORB的出現(xiàn)簡化了這一過程。使用ORB時,協(xié)議是使用接口定義語言(IDL)定義的,而IDL是獨立于語言的。并且ORB提供很強的靈活性,它使程序員選擇最適合的操作系統(tǒng)、執(zhí)行環(huán)境,甚至系統(tǒng)各個組件也可以采用不同的編程語言實現(xiàn)。更重要的是,它允許現(xiàn)有組件的集成。在一個基于ORB的解決方案中,開發(fā)者可以使用與創(chuàng)建新對象一樣的IDL對遺留系統(tǒng)進行建模,他們創(chuàng)建“包裝”代碼以在標(biāo)準(zhǔn)化的軟件總線與遺留系統(tǒng)接口之間傳遞信息。
使用CORBA,用戶可以透明地訪問信息,并不需要知道信息存在于什么軟件中、使用什么硬件平臺,以及位于企業(yè)網(wǎng)絡(luò)的什么地方。作為面向?qū)ο笙到y(tǒng)的通信核心,CORBA為今天的計算環(huán)境帶來了真正的互操作性。
■CORBA與JAVA的相互關(guān)系
CORBA不只意味著對象請求代理(ORB),它還是非常全面的分布式對象平臺。CORBA使JAVA應(yīng)用可以跨越網(wǎng)絡(luò)、語言以及操作系統(tǒng),并為JAVA提供了一組分布服務(wù),如分布式自我觀察、動態(tài)發(fā)現(xiàn)、事務(wù)、關(guān)系、安全和命名等。
JAVA不僅是一種語言,它還是一個動態(tài)代碼系統(tǒng),它對運行對象來說是一個可移植的虛擬機(JVM)。JAVA為開發(fā)、管理、發(fā)布Client/Server應(yīng)用提供了更簡單的方式。人們可以通過將應(yīng)用放在一個Web服務(wù)器上將這一應(yīng)用發(fā)布給成千上萬個用戶,而不必關(guān)心它的安裝和升級。JAVA還非常適合服務(wù)器的開發(fā),它可以動態(tài)地將服務(wù)代碼移向最需要它們的地方。
JAVA將會使CORBA對象能夠運行在從主機、網(wǎng)絡(luò)計算機到蜂窩電話等可編程的各種機器上,并簡化了大型CORBA系統(tǒng)的代碼發(fā)布。對客戶和服務(wù)對象來說JAVA是很理想的編程語言,JAVA內(nèi)置的多線程、垃圾收集和錯誤處理使編寫健壯的網(wǎng)絡(luò)對象變得很容易。
這兩種對象模型可以很好地相互補充,CORBA處理網(wǎng)絡(luò)的透明性,JAVA處理實現(xiàn)的透明性,CORBA為JAVA可移植應(yīng)用環(huán)境提供了一個分布式的結(jié)構(gòu)。
■使用JAVA開發(fā)CORBA應(yīng)用
下面讓我簡要介紹一下開發(fā)CORBA的步驟。
使用JAVA開發(fā)CORBA應(yīng)用需要如下五個步驟:
使用IDL創(chuàng)建接口 (About.idl) 下面的OMG IDL描述一個CORBA對象。 module About { interface Show { string ShowName(); }; }; 將其存為Show.idl。 編譯接口并生成CORBA支持文件 我們用以下命令編譯這個 IDL 接口: idltojava Show.idl idltojava是SUN公司的IDL編譯器,可以免費從SUN公司站點上下載。 因為idltojava在編譯IDL文件之前,需要進行預(yù)編譯,而如果你的機器上沒有預(yù)編譯器,可以使用以下命令: idltojava -fno-cpp Show.idl 編譯后將在當(dāng)前目錄下生成About子目錄,其中會包括一些支持文件,如有興趣可以看一下,但一定不要修改。 實現(xiàn)服務(wù)器 (ShowServer.java) ShowServer的main() 方法,可完成以下任務(wù): 創(chuàng)建一個 ORB 實例 創(chuàng)建一個服務(wù)對象實例(CORBA About 對象的實現(xiàn))并通知 ORB 獲取一個命名上下文的CORBA對象引用,在該命名上下文中注冊新的CORBA對象 在命名上下文中將新對象注冊在“About”名下 等待對新對象的調(diào)用 實現(xiàn)服務(wù)器源程序如下: import About.; import org.omg.CosNaming.; import org.omg.CosNaming.NamingContextPackage.; import org.omg.CORBA.; class ShowObject extends _ShowImplBase { public String ShowName() { return "\nMy name is Seymour!!\n"; } } public class ShowServer { public static void main(String args[]) { try{ // 創(chuàng)建和初始化 ORB ORB orb = ORB.init(args, null); // 創(chuàng)建服務(wù)對象并將其向 ORB 注冊 ShowObject ShowRef = new ShowObject(); orb.connect(ShowRef); // 獲取根命名上下文 org.omg.CORBA.Object objRef = orb.resolve_initial_references("NameService"); NamingContext ncRef = NamingContextHelper.narrow(objRef); // 綁定命名中的對象引用 NameComponent nc = new NameComponent("About", ""); NameComponent path[] = {nc}; ncRef.rebind(path, ShowRef); // 等待來自客戶機的調(diào)用 java.lang.Object sync = new java.lang.Object(); synchronized (sync) { sync.wait(); } } catch (Exception e) { System.err.println("ERROR: " + e); e.printStackTrace(System.out); } } } 實現(xiàn)客戶機 (ShowClient.java) 下面的應(yīng)用程序客戶機將完成以下任務(wù): 創(chuàng)建一個ORB; 獲取一個指向命名上下文的引用; 在命名上下文中查找“Show”并獲得指向該 CORBA 對象的引用; 調(diào)用對象的 ShowName() 操作并打印結(jié)果。 import About.; import org.omg.CosNaming.; import org.omg.CORBA.; public class ShowClient { public static void main(String args[]) { try{ // 創(chuàng)建和初始化 ORB ORB orb = ORB.init(args, null); // 獲取根命名上下文 org.omg.CORBA.Object objRef = orb.resolve_initial_references("NameService"); NamingContext ncRef = NamingContextHelper.narrow(objRef); //解析命名中的對象引用 NameComponent nc = new NameComponent("About", ""); NameComponent path[] = {nc}; About.Show ShowRef = ShowHelper.narrow(ncRef.resolve(path)); // 調(diào)用 Show 服務(wù)對象并打印結(jié)果 String show = ShowRef.ShowName(); System.out.println(show); } catch (Exception e) { System.out.println("ERROR : " + e) ; e.printStackTrace(System.out); } } } 構(gòu)建和運行ShowName程序 編譯 .java 文件,包括 stub 和 skeleton(在About目錄中): javac .java About/.java 啟動一個MS-DOS命令解釋器,輸入以下命令,確保名字服務(wù)器處于運行狀態(tài): tnameserv -ORBInitialPort 1050 啟動另一個MS-Dos命令解釋器,輸入以下命令,啟動Show服務(wù)器: java ShowServer -ORBInitialPort 1050 再啟動一個MS-Dos命令解釋器Show應(yīng)用程序客戶機: java ShowClient -ORBInitialPort 1050 這時屏幕上會出現(xiàn)“My name is Seymour!”的字樣,說明實驗已經(jīng)成功了。 本示例程序在Windows 98、Java 1.2.2平臺下實現(xiàn)。
|