?? 使用java開(kāi)發(fā)corba應(yīng)用.txt
字號(hào):
作者:爬蟲(chóng)
email: xxx@xxx.xx
日期:2001-5-8 17:42:40
■CORBA技術(shù)簡(jiǎn)介
簡(jiǎn)單地說(shuō),CORBA允許應(yīng)用之間相互通信,而不管它們存在于哪里以及是誰(shuí)設(shè)計(jì)的。CORBA1.1于1991年由OMG發(fā)布,其中定義了接口定義語(yǔ)言(IDL)以及在對(duì)象請(qǐng)求代理(ORB)中實(shí)現(xiàn)客戶對(duì)象與服務(wù)器對(duì)象之間交互的應(yīng)用編程接口(API)。CORBA2.0于1994年發(fā)布,規(guī)定了各個(gè)供應(yīng)商之間的ORB的通信規(guī)則?! ?
CORBA標(biāo)準(zhǔn)主要分為三個(gè)部分:接口定義語(yǔ)言(IDL)、對(duì)象請(qǐng)求代理(ORB)以及ORB之間的互操作協(xié)議IIOP?! ?
ORB是對(duì)象之間建立Client/Server關(guān)系的中間件。使用ORB,客戶可以透明地調(diào)用一個(gè)服務(wù)對(duì)象上的方法,這個(gè)服務(wù)對(duì)象可以在本地,也可以在通過(guò)網(wǎng)絡(luò)連接的其他機(jī)器上。ORB截獲這一調(diào)用同時(shí)負(fù)責(zé)查找實(shí)現(xiàn)服務(wù)的對(duì)象并向其傳遞參數(shù)、調(diào)用方法返回最終結(jié)果??蛻舨⒉恢婪?wù)對(duì)象位于什么地方,它的編程語(yǔ)言和操作系統(tǒng)是什么,也不知道不屬于對(duì)象接口的其他系統(tǒng)部分。這樣,ORB在異構(gòu)分布環(huán)境下為不同機(jī)器上的應(yīng)用提供了互操作性,并無(wú)縫地集成了多種對(duì)象系統(tǒng)?! ?
在開(kāi)發(fā)傳統(tǒng)的Client/Server應(yīng)用時(shí),開(kāi)發(fā)者使用他們自己設(shè)計(jì)的或一個(gè)公認(rèn)的標(biāo)準(zhǔn)來(lái)定義用于設(shè)備之間通信的協(xié)議。協(xié)議的定義依賴于實(shí)現(xiàn)語(yǔ)言、網(wǎng)絡(luò)傳輸和許多其他因素,而ORB的出現(xiàn)簡(jiǎn)化了這一過(guò)程。使用ORB時(shí),協(xié)議是使用接口定義語(yǔ)言(IDL)定義的,而IDL是獨(dú)立于語(yǔ)言的。并且ORB提供很強(qiáng)的靈活性,它使程序員選擇最適合的操作系統(tǒng)、執(zhí)行環(huán)境,甚至系統(tǒng)各個(gè)組件也可以采用不同的編程語(yǔ)言實(shí)現(xiàn)。更重要的是,它允許現(xiàn)有組件的集成。在一個(gè)基于ORB的解決方案中,開(kāi)發(fā)者可以使用與創(chuàng)建新對(duì)象一樣的IDL對(duì)遺留系統(tǒng)進(jìn)行建模,他們創(chuàng)建“包裝”代碼以在標(biāo)準(zhǔn)化的軟件總線與遺留系統(tǒng)接口之間傳遞信息?! ?
使用CORBA,用戶可以透明地訪問(wèn)信息,并不需要知道信息存在于什么軟件中、使用什么硬件平臺(tái),以及位于企業(yè)網(wǎng)絡(luò)的什么地方。作為面向?qū)ο笙到y(tǒng)的通信核心,CORBA為今天的計(jì)算環(huán)境帶來(lái)了真正的互操作性。
■CORBA與JAVA的相互關(guān)系
CORBA不只意味著對(duì)象請(qǐng)求代理(ORB),它還是非常全面的分布式對(duì)象平臺(tái)。CORBA使JAVA應(yīng)用可以跨越網(wǎng)絡(luò)、語(yǔ)言以及操作系統(tǒng),并為JAVA提供了一組分布服務(wù),如分布式自我觀察、動(dòng)態(tài)發(fā)現(xiàn)、事務(wù)、關(guān)系、安全和命名等?! ?
JAVA不僅是一種語(yǔ)言,它還是一個(gè)動(dòng)態(tài)代碼系統(tǒng),它對(duì)運(yùn)行對(duì)象來(lái)說(shuō)是一個(gè)可移植的虛擬機(jī)(JVM)。JAVA為開(kāi)發(fā)、管理、發(fā)布Client/Server應(yīng)用提供了更簡(jiǎn)單的方式。人們可以通過(guò)將應(yīng)用放在一個(gè)Web服務(wù)器上將這一應(yīng)用發(fā)布給成千上萬(wàn)個(gè)用戶,而不必關(guān)心它的安裝和升級(jí)。JAVA還非常適合服務(wù)器的開(kāi)發(fā),它可以動(dòng)態(tài)地將服務(wù)代碼移向最需要它們的地方?! ?
JAVA將會(huì)使CORBA對(duì)象能夠運(yùn)行在從主機(jī)、網(wǎng)絡(luò)計(jì)算機(jī)到蜂窩電話等可編程的各種機(jī)器上,并簡(jiǎn)化了大型CORBA系統(tǒng)的代碼發(fā)布。對(duì)客戶和服務(wù)對(duì)象來(lái)說(shuō)JAVA是很理想的編程語(yǔ)言,JAVA內(nèi)置的多線程、垃圾收集和錯(cuò)誤處理使編寫健壯的網(wǎng)絡(luò)對(duì)象變得很容易。
這兩種對(duì)象模型可以很好地相互補(bǔ)充,CORBA處理網(wǎng)絡(luò)的透明性,JAVA處理實(shí)現(xiàn)的透明性,CORBA為JAVA可移植應(yīng)用環(huán)境提供了一個(gè)分布式的結(jié)構(gòu)。
■使用JAVA開(kāi)發(fā)CORBA應(yīng)用
下面讓我簡(jiǎn)要介紹一下開(kāi)發(fā)CORBA的步驟?! ?
使用JAVA開(kāi)發(fā)CORBA應(yīng)用需要如下五個(gè)步驟:
使用IDL創(chuàng)建接口 (About.idl)
下面的OMG IDL描述一個(gè)CORBA對(duì)象。
module About
{
interface Show
{
string ShowName();
};
};
將其存為Show.idl?! ?編譯接口并生成CORBA支持文件
我們用以下命令編譯這個(gè) IDL 接口:
idltojava Show.idl
idltojava是SUN公司的IDL編譯器,可以免費(fèi)從SUN公司站點(diǎn)上下載。
因?yàn)閕dltojava在編譯IDL文件之前,需要進(jìn)行預(yù)編譯,而如果你的機(jī)器上沒(méi)有預(yù)編譯器,可以使用以下命令:
idltojava -fno-cpp Show.idl
編譯后將在當(dāng)前目錄下生成About子目錄,其中會(huì)包括一些支持文件,如有興趣可以看一下,但一定不要修改?! ?實(shí)現(xiàn)服務(wù)器 (ShowServer.java)
ShowServer的main() 方法,可完成以下任務(wù):
創(chuàng)建一個(gè) ORB 實(shí)例
創(chuàng)建一個(gè)服務(wù)對(duì)象實(shí)例(CORBA About 對(duì)象的實(shí)現(xiàn))并通知 ORB
獲取一個(gè)命名上下文的CORBA對(duì)象引用,在該命名上下文中注冊(cè)新的CORBA對(duì)象
在命名上下文中將新對(duì)象注冊(cè)在“About”名下
等待對(duì)新對(duì)象的調(diào)用
實(shí)現(xiàn)服務(wù)器源程序如下:
import About.
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -