?? 5.3 corba技術(shù)及實(shí)例.txt
字號(hào):
作者:easyinfonet
email: easyinfonet@sina.com.cn
日期:2000-11-14 23:15:19
5.3 CORBA技術(shù)及實(shí)例
CORBA是一種規(guī)范,它定義了分布式對(duì)象如何實(shí)現(xiàn)互操作。在WorldWideWeb盛行之前,特別是Java編程語(yǔ)言風(fēng)靡之前,C++開(kāi)發(fā)者基本將CORBA作為其高端分布式對(duì)象的解決方案。
實(shí)際的CORBA規(guī)范歸對(duì)象管理組(ObjeotManagementGroup)管轄,這是一家由700多家公司組成的開(kāi)放的研討會(huì),其工作是制訂對(duì)象計(jì)算的開(kāi)放標(biāo)準(zhǔn)。CORBA對(duì)象可以用任何一種CORBA軟件開(kāi)發(fā)商所支持的語(yǔ)言,如C、C++、Java、Ada和Smalltalk,來(lái)編寫(xiě)。同樣地,CORBA對(duì)象可以運(yùn)行在任何一種CORBA軟件開(kāi)發(fā)商所支持的平臺(tái)上,如Solaris,Windows95/NT,OpenVMS、DigitalUnix、HP-UX或AIX等。這意味著,我們可以在Windows95下運(yùn)行Java應(yīng)用程序,同時(shí)動(dòng)態(tài)調(diào)入并使用C++對(duì)象,而實(shí)際上,該對(duì)象可能存儲(chǔ)于一個(gè)在Internet上的UnixWeb服務(wù)器上。
使用 接口描述語(yǔ)言(InterfaceDescriptionLanguage)編寫(xiě)的對(duì)象接口,使得與語(yǔ)言無(wú)關(guān)的獨(dú)立性成為可能。IDL使得所有CORBA對(duì)象以一種方式被描述,僅僅需要一個(gè)由本地語(yǔ)言(C/C++、CORBA、Java)到IDL的“橋梁”。CORBA對(duì)象的互通信要以對(duì)象請(qǐng)求解析器(Object Request Broker)為中介,這種互通可以在多種流行通信協(xié)議之上(如TCP/IP或是IPX/SPX)實(shí)現(xiàn)。在TCP/IP上,來(lái)自于不同開(kāi)發(fā)商的ORB用InternetInter-Orb協(xié)議(IIOP)進(jìn)行通訊,這是CORBA2.0標(biāo)準(zhǔn)(最新的版本)的一部分。
目前,對(duì)于較為流行的編程語(yǔ)言(包括C++,Smalltalk,Java和Ada95),已經(jīng)有了許多第三方的ORB。隨著其他語(yǔ)言的逐漸流行,CORBA開(kāi)發(fā)商毫無(wú)疑問(wèn)地要做出相應(yīng)的ORB來(lái)支持它們。
5.3.1 CORBA簡(jiǎn)介
最初,OMG在1990年制訂了對(duì)象管理體系(ObjectManagementArchitecture),即OMA,來(lái)描述應(yīng)用程序如何實(shí)現(xiàn)互操作。作為其中的一部分,需要有一個(gè)標(biāo)準(zhǔn)規(guī)范應(yīng)用程序片段即對(duì)象的互操作──這導(dǎo)致了CORBA的誕生。OMA定義了組成CORBA的四個(gè)主要部分。(圖1.1)
圖1.1 OMG的CORBA參考模型
l Object Request Broker,ORB作為對(duì)象互通訊的軟總線。
l Object Services,定義加入ORB的系統(tǒng)級(jí)服務(wù),如安全性、命名和事務(wù)處理。
l Common Facilities定義應(yīng)用程序級(jí)服務(wù),如復(fù)合文檔等。
l Application Interface 定義現(xiàn)實(shí)世界的對(duì)象和應(yīng)用,如飛機(jī)或銀行帳戶(hù)。
1.ObjectRequestBroker詳述
OMA最重要的部分就是ORB。為了創(chuàng)建一個(gè)遵從CORBA規(guī)范的應(yīng)用程序,ORB是CORBA四大部分中唯一必須提供的。許多ORB版本根本不帶CORBAServices或是CORBAFacilities,你可以自制(或購(gòu)買(mǎi))商用對(duì)象。但是,沒(méi)有ORB,CORBA應(yīng)用程序絕對(duì)無(wú)法工作。(圖5.2)
圖5-.2 單個(gè)ORB的體系結(jié)構(gòu)
CORB ORB最顯見(jiàn)的功能,是對(duì)你的應(yīng)用程序或是其它ORB的請(qǐng)求予以響應(yīng)。在CORBA應(yīng)用程序運(yùn)行期間,你的ORB可能被請(qǐng)求做許多不同的事情,包括:
l 查找并調(diào)用遠(yuǎn)程計(jì)算機(jī)上的對(duì)象
l 負(fù)責(zé)不同編程語(yǔ)言之間的參數(shù)轉(zhuǎn)換(如C++到Java)
l 可超越本機(jī)界限的安全管理
l 為其它的ORB收集并發(fā)布本地對(duì)象的metadata
l 用下載的代碼(stub)中描述的靜態(tài)方法調(diào)用去擊活遠(yuǎn)程對(duì)象中的方法
l 用動(dòng)態(tài)方法調(diào)用擊活遠(yuǎn)程對(duì)象
l 自動(dòng)擊活一個(gè)當(dāng)前沒(méi)有裝入內(nèi)存運(yùn)行的對(duì)象。
l 將回調(diào)方法導(dǎo)引向其管理之下的本地對(duì)象
實(shí)現(xiàn)細(xì)節(jié)對(duì)軟件開(kāi)發(fā)者的透明性,是ORB的一個(gè)杰出的特性。用戶(hù)只須在代碼中提供相應(yīng)的hooks,用于初始化ORB并向ORB登記該應(yīng)用程序,就可以將該應(yīng)用程序和大量分布式對(duì)象建立聯(lián)系。
2.用IDL描述對(duì)象
為了保持CORBA的商業(yè)中立性和語(yǔ)言中立性,必須有一個(gè)中介,存在于象C++CORBA服務(wù)器代碼和JavaCORBA客戶(hù)機(jī)這樣的實(shí)體之間。這就是IDL。一個(gè)底層對(duì)象的若干相關(guān)方法和屬性被IDL集入一個(gè)單一接口。一旦IDL接口定義完成,它可以以stub碼或框架代碼(skeletoncode)的形式編譯成你選用的語(yǔ)言。在所有的ORB中都有IDL編譯器。例如,VisigenicVisiBrokerforJavaORB中就含有Java/IDL編譯器,而VisigenicVisiBrokerforC++ORB則提供了C++/IDL編譯器。
有一點(diǎn)值得注意的是IDL不同于其它的面向?qū)ο蟪绦蛟O(shè)計(jì)語(yǔ)言,我們不能用它指定它所定義的類(lèi)或是方法的具體實(shí)現(xiàn)。因此,將它僅僅作為一種定義底層對(duì)象接口的語(yǔ)言要好得多。
就象在Java中將屬性和方法封裝到相關(guān)的類(lèi)中一樣,上述各項(xiàng)均包含在IDL的模塊之中。在一個(gè)模塊之中可以定義一個(gè)或多個(gè)接口。表一中的簡(jiǎn)單IDL模塊名為T(mén)heModule,它含有一個(gè)稱(chēng)為T(mén)heInterface的基本接口。該接口僅有一個(gè)定義為整型的簡(jiǎn)單變量(即TheVariable)。
5.3.2 用Java做CORBA開(kāi)發(fā)實(shí)例
為了創(chuàng)建一個(gè)分布式的Java小應(yīng)用,并讓它用CORBA訪問(wèn)服務(wù)器對(duì)象,我們利用一個(gè)流行的商用ORB,并用IDL定義對(duì)象接口。在示例小應(yīng)用中,我們選用了Visigenic VisiBroker for Java。這種ORB已經(jīng)經(jīng)過(guò)Oracle、Netscape和Novell等公司的認(rèn)證,并已被納入NetscapeNavigator4.0。
注意:你可以在非NetscapeNavigator4.0的瀏覽器中運(yùn)行這個(gè)小應(yīng)用。由于它首先要從別處下載一些Java類(lèi)文件,啟動(dòng)速度可能會(huì)稍慢一些。
我們將用一個(gè)簡(jiǎn)單的Java小應(yīng)用調(diào)用一個(gè)使用CORBA的服務(wù)器對(duì)象。為簡(jiǎn)單起見(jiàn),同樣用Java書(shū)寫(xiě)服務(wù)器對(duì)象。該服務(wù)器對(duì)象用一個(gè)數(shù)組存儲(chǔ)有關(guān)各種CORBAORB開(kāi)發(fā)商及他們產(chǎn)品的信息。客戶(hù)小應(yīng)用將調(diào)用該對(duì)象并查詢(xún)數(shù)組。一個(gè)更為完整的例子(仔細(xì)思考一下)是將ORB信息存儲(chǔ)于關(guān)系數(shù)據(jù)庫(kù)中,利用JDBC(或是別的數(shù)據(jù)庫(kù)訪問(wèn)方法)獲得相關(guān)信息。這種方法將用CORBA生成一個(gè)真正的三層應(yīng)用程序。
1.最簡(jiǎn)單的IDL模塊
Module TheModule
{
interface TheInterface
{
long TheVariable;
};
};
如果你用一個(gè)IDL到Java的編譯器編譯這個(gè)IDL模塊(如Visigenic的idl2java),就會(huì)得到表1-2中的Java接口。
表1-2與TheModule相應(yīng)的Java代碼
package TheModule;
public interface TheInterface
{
public int TheVariable;
}
2.ORBQuery小應(yīng)用
這個(gè)客戶(hù)端的小應(yīng)用含有標(biāo)準(zhǔn)的JavaGUI,并將調(diào)用一個(gè)遠(yuǎn)程CORBA對(duì)象。一旦該對(duì)象被調(diào)用,就可以使用其方法獲得某一指定CORBA ORB的信息。在服務(wù)器端,為了獲得特定ORB的如下信息:名稱(chēng)(Name)、銷(xiāo)售商(Vendor)、操作系統(tǒng)(OperatingSystem)、語(yǔ)言(Languages)和URL,我們必須定義五個(gè)方法。因此,必須在IDL接口中定義這五種方法才能獲取相應(yīng)信息。表1-3定義了這個(gè)名為ORBInfo的接口:
表1-3:ORBInfoIDL界面
module ORBQuery
{
interface ORBInfo
{
string GetName(in long index);
string GetVendor(in long index);
string GetOS(in long index);
string GetLanguages(in long index);
string GetURL(in long index);
};
};VisiBroker安裝中含有一個(gè)IDL編譯器──idl2java,你可以用它生成實(shí)現(xiàn)該接口必需的Java代碼。軟件安裝完成之后,只要執(zhí)行如下命令即可生成代碼:
idl2javaORBInfo.idl
這步操作將創(chuàng)建一個(gè)名為ORBQuery的子目錄(與ORBQueryJava包相對(duì)應(yīng))。在該目錄內(nèi)有8個(gè)文件:ORBInfo.java,ORBInfoHolder.java、ORBInfoHelper.java、_st_ORBInfo.java,_sk_ORBInfo.java、ORBInfoOperations.java、_tie_ORBInfo.java和_example_ORBInfo.java。你可能已經(jīng)猜到,ORBInfo.java文件含有定義ORBInfo接口的Java源文件,但其它的Java類(lèi)又怎樣呢?
ORBInfoHolder.java文件內(nèi)含有一個(gè)傳遞參數(shù)時(shí)使用的主類(lèi)(holderclass),而ORBInfo-Helper類(lèi)則定義了各種實(shí)用函數(shù)。_st_ORBInfo類(lèi)定義了客戶(hù)stub,_sk_ORBInfo定義了服務(wù)器框架類(lèi)(skeletonclass)。
ORBInfoOperations和_tie_ORBInfo類(lèi)用于實(shí)現(xiàn)一種捆綁機(jī)制,這是VisiBroker的一個(gè)特性,它使得實(shí)現(xiàn)類(lèi)能夠繼承框架類(lèi)之外的類(lèi)。在示例中,我們不會(huì)直接使用這幾個(gè)類(lèi)。最后,_example_ORBInfo含有一個(gè)示例服務(wù)器對(duì)象,對(duì)它加以擴(kuò)展就可創(chuàng)建一個(gè)服務(wù)器應(yīng)用程序。
通過(guò)IDL編譯器生成的這八個(gè)Java類(lèi),我們可以構(gòu)建一個(gè)框架,由一個(gè)接口(interface)、一個(gè)stub、一個(gè)skeleton和幾個(gè)幫助類(lèi),我們可以用Java創(chuàng)建自己的客戶(hù)機(jī)/服務(wù)器模式的CORBA應(yīng)用程序。
3.創(chuàng)建服務(wù)器應(yīng)用程序
下面,我們需要?jiǎng)?chuàng)建一個(gè)向服務(wù)器ORB登記ORBInfo對(duì)象的服務(wù)器應(yīng)用程序。這個(gè)新對(duì)象將擴(kuò)充框架類(lèi)(skeletonclass)并實(shí)現(xiàn)ORBInfo接口。因此,該服務(wù)器共需兩個(gè)新類(lèi):一個(gè)用于定義服務(wù)器對(duì)象并實(shí)現(xiàn)ORBInfo接口,另一個(gè)向服務(wù)器ORB登記該對(duì)象。ORBQuery類(lèi)包含的標(biāo)準(zhǔn)Java代碼負(fù)責(zé)取回?cái)?shù)組中的指定元素。Server類(lèi)中含有CORBA特有的功能。
接下來(lái)的例子中,開(kāi)始是初始化ORB。然后,用“ORBInfo”字符串向ORB登記類(lèi),客戶(hù)機(jī)利用這個(gè)字符串檢索一個(gè)對(duì)象。所有的操作完成后,調(diào)用boa.obj_is_ready(),通知ORB一切準(zhǔn)備就緒。
表1-4是Server類(lèi),它向ORB登記了ORBInfo對(duì)象。
表1-4 服務(wù)器類(lèi)
public class Server {
public static void main(String[] args) {
try {
// Initialize the ORB.
org.omg.CORBA.ORB orb = org.omg.CORBA.ORB.init();
// Initialize the BOA.
org.omg.CORBA.BOA boa = orb.BOA_init();
// Create the ORBQuery.
ORBQuery serverQuery = new ORBQuery("ORBInfo");
// Export the newly create object.
boa.obj_is_ready(serverQuery);
System.out.println(serverQuery + " is ready.");
// Wait for incoming requests
boa.impl_is_ready();
}
catch(org.omg.CORBA.SystemException e) {
System.err.println(e);
}
}
}
表1-5給出了ORBQuery類(lèi),它實(shí)現(xiàn)了接口及五個(gè)幫助方法。
表1-5:ORBQuery類(lèi)
import java.util.*;
class ORBQuery extends ORBQuery._sk_ORBInfo {
String[][] ORBVendors =
{{"PowerBroker","Orbix","VisiBroker","ComponentBroker","
Solaris NEO"},
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -