5.3 CORBA技術(shù)及案例
發(fā)表時(shí)間:2023-07-30 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]5.3CORBA技術(shù)及實(shí)例 CORBA是一種規(guī)范,它定義了分布式對(duì)象如何實(shí)現(xiàn)互操作。在WorldWideWeb盛行之前,特別是Java編程語言風(fēng)靡之前,C++開發(fā)者基本將CORBA作為其高端分布式對(duì)...
5.3CORBA技術(shù)及實(shí)例
CORBA是一種規(guī)范,它定義了分布式對(duì)象如何實(shí)現(xiàn)互操作。在WorldWideWeb盛行之前,特別是Java編程語言風(fēng)靡之前,C++開發(fā)者基本將CORBA作為其高端分布式對(duì)象的解決方案。
實(shí)際的CORBA規(guī)范歸對(duì)象管理組(ObjeotManagementGroup)管轄,這是一家由700多家公司組成的開放的研討會(huì),其工作是制訂對(duì)象計(jì)算的開放標(biāo)準(zhǔn)。CORBA對(duì)象可以用任何一種CORBA軟件開發(fā)商所支持的語言,如C、C++、Java、Ada和Smalltalk,來編寫。同樣地,CORBA對(duì)象可以運(yùn)行在任何一種CORBA軟件開發(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ù)器上。
使用接口描述語言(InterfaceDescriptionLanguage)編寫的對(duì)象接口,使得與語言無關(guān)的獨(dú)立性成為可能。IDL使得所有CORBA對(duì)象以一種方式被描述,僅僅需要一個(gè)由本地語言(C/C++、CORBA、Java)到IDL的“橋梁”。CORBA對(duì)象的互通信要以對(duì)象請(qǐng)求解析器(Object Request Broker)為中介,這種互通可以在多種流行通信協(xié)議之上(如TCP/IP或是IPX/SPX)實(shí)現(xiàn)。在TCP/IP上,來自于不同開發(fā)商的ORB用InternetInter-Orb協(xié)議(IIOP)進(jìn)行通訊,這是CORBA2.0標(biāo)準(zhǔn)(最新的版本)的一部分。
目前,對(duì)于較為流行的編程語言(包括C++,Smalltalk,Java和Ada95),已經(jīng)有了許多第三方的ORB。隨著其他語言的逐漸流行,CORBA開發(fā)商毫無疑問地要做出相應(yīng)的ORB來支持它們。
5.3.1CORBA簡(jiǎn)介
最初,OMG在1990年制訂了對(duì)象管理體系(ObjectManagementArchitecture),即OMA,來描述應(yīng)用程序如何實(shí)現(xiàn)互操作。作為其中的一部分,需要有一個(gè)標(biāo)準(zhǔn)規(guī)范應(yīng)用程序片段即對(duì)象的互操作──這導(dǎo)致了CORBA的誕生。OMA定義了組成CORBA的四個(gè)主要部分。(圖1.1)
圖1.1OMG的CORBA參考模型
lObject Request Broker,ORB作為對(duì)象互通訊的軟總線。
lObject Services,定義加入ORB的系統(tǒng)級(jí)服務(wù),如安全性、命名和事務(wù)處理。
lCommon Facilities定義應(yīng)用程序級(jí)服務(wù),如復(fù)合文檔等。
lApplication Interface 定義現(xiàn)實(shí)世界的對(duì)象和應(yīng)用,如飛機(jī)或銀行帳戶。
1.ObjectRequestBroker詳述
OMA最重要的部分就是ORB。為了創(chuàng)建一個(gè)遵從CORBA規(guī)范的應(yīng)用程序,ORB是CORBA四大部分中唯一必須提供的。許多ORB版本根本不帶CORBAServices或是CORBAFacilities,你可以自制(或購買)商用對(duì)象。但是,沒有ORB,CORBA應(yīng)用程序絕對(duì)無法工作。(圖5.2)
圖5-.2 單個(gè)ORB的體系結(jié)構(gòu)
CORB ORB最顯見的功能,是對(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é)不同編程語言之間的參數(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)前沒有裝入內(nèi)存運(yùn)行的對(duì)象。
l將回調(diào)方法導(dǎo)引向其管理之下的本地對(duì)象
實(shí)現(xiàn)細(xì)節(jié)對(duì)軟件開發(fā)者的透明性,是ORB的一個(gè)杰出的特性。用戶只須在代碼中提供相應(yīng)的hooks,用于初始化ORB并向ORB登記該應(yīng)用程序,就可以將該應(yīng)用程序和大量分布式對(duì)象建立聯(lián)系。
2.用IDL描述對(duì)象
為了保持CORBA的商業(yè)中立性和語言中立性,必須有一個(gè)中介,存在于象C++CORBA服務(wù)器代碼和JavaCORBA客戶機(jī)這樣的實(shí)體之間。這就是IDL。一個(gè)底層對(duì)象的若干相關(guān)方法和屬性被IDL集入一個(gè)單一接口。一旦IDL接口定義完成,它可以以stub碼或框架代碼(skeletoncode)的形式編譯成你選用的語言。在所有的ORB中都有IDL編譯器。例如,VisigenicVisiBrokerforJavaORB中就含有Java/IDL編譯器,而VisigenicVisiBrokerforC++ORB則提供了C++/IDL編譯器。
有一點(diǎn)值得注意的是IDL不同于其它的面向?qū)ο蟪绦蛟O(shè)計(jì)語言,我們不能用它指定它所定義的類或是方法的具體實(shí)現(xiàn)。因此,將它僅僅作為一種定義底層對(duì)象接口的語言要好得多。
就象在Java中將屬性和方法封裝到相關(guān)的類中一樣,上述各項(xiàng)均包含在IDL的模塊之中。在一個(gè)模塊之中可以定義一個(gè)或多個(gè)接口。表一中的簡(jiǎn)單IDL模塊名為TheModule,它含有一個(gè)稱為TheInterface的基本接口。該接口僅有一個(gè)定義為整型的簡(jiǎn)單變量(即TheVariable)。
5.3.2用Java做CORBA開發(fā)實(shí)例
為了創(chuàng)建一個(gè)分布式的Java小應(yīng)用,并讓它用CORBA訪問服務(wù)器對(duì)象,我們利用一個(gè)流行的商用ORB,并用IDL定義對(duì)象接口。在示例小應(yīng)用中,我們選用了Visigenic VisiBroker for Java。這種ORB已經(jīng)經(jīng)過Oracle、Netscape和Novell等公司的認(rèn)證,并已被納入NetscapeNavigator4.0。
注意:你可以在非NetscapeNavigator4.0的瀏覽器中運(yùn)行這個(gè)小應(yīng)用。由于它首先要從別處下載一些Java類文件,啟動(dòng)速度可能會(huì)稍慢一些。
我們將用一個(gè)簡(jiǎn)單的Java小應(yīng)用調(diào)用一個(gè)使用CORBA的服務(wù)器對(duì)象。為簡(jiǎn)單起見,同樣用Java書寫服務(wù)器對(duì)象。該服務(wù)器對(duì)象用一個(gè)數(shù)組存儲(chǔ)有關(guān)各種CORBAORB開發(fā)商及他們產(chǎn)品的信息。客戶小應(yīng)用將調(diào)用該對(duì)象并查詢數(shù)組。一個(gè)更為完整的例子(仔細(xì)思考一下)是將ORB信息存儲(chǔ)于關(guān)系數(shù)據(jù)庫中,利用JDBC(或是別的數(shù)據(jù)庫訪問方法)獲得相關(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è)客戶端的小應(yīng)用含有標(biāo)準(zhǔn)的JavaGUI,并將調(diào)用一個(gè)遠(yuǎn)程CORBA對(duì)象。一旦該對(duì)象被調(diào)用,就可以使用其方法獲得某一指定CORBA ORB的信息。在服務(wù)器端,為了獲得特定ORB的如下信息:名稱(Name)、銷售商(Vendor)、操作系統(tǒng)(OperatingSystem)、語言(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 longindex);
string GetOS(in long index);
string GetLanguages(in longindex);
string GetURL(in longindex);
};
};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類又怎樣呢?
ORBInfoHolder.java文件內(nèi)含有一個(gè)傳遞參數(shù)時(shí)使用的主類(holderclass),而ORBInfo-Helper類則定義了各種實(shí)用函數(shù)。_st_ORBInfo類定義了客戶stub,_sk_ORBInfo定義了服務(wù)器框架類(skeletonclass)。
ORBInfoOperations和_tie_ORBInfo類用于實(shí)現(xiàn)一種捆綁機(jī)制,這是VisiBroker的一個(gè)特性,它使得實(shí)現(xiàn)類能夠繼承框架類之外的類。在示例中,我們不會(huì)直接使用這幾個(gè)類。最后,_example_ORBInfo含有一個(gè)示例服務(wù)器對(duì)象,對(duì)它加以擴(kuò)展就可創(chuàng)建一個(gè)服務(wù)器應(yīng)用程序。
通過IDL編譯器生成的這八個(gè)Java類,我們可以構(gòu)建一個(gè)框架,由一個(gè)接口(interface)、一個(gè)stub、一個(gè)skeleton和幾個(gè)幫助類,我們可以用Java創(chuàng)建自己的客戶機(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ò)充框架類(skeletonclass)并實(shí)現(xiàn)ORBInfo接口。因此,該服務(wù)器共需兩個(gè)新類:一個(gè)用于定義服務(wù)器對(duì)象并實(shí)現(xiàn)ORBInfo接口,另一個(gè)向服務(wù)器ORB登記該對(duì)象。ORBQuery類包含的標(biāo)準(zhǔn)Java代碼負(fù)責(zé)取回?cái)?shù)組中的指定元素。Server類中含有CORBA特有的功能。
接下來的例子中,開始是初始化ORB。然后,用“ORBInfo”字符串向ORB登記類,客戶機(jī)利用這個(gè)字符串檢索一個(gè)對(duì)象。所有的操作完成后,調(diào)用boa.obj_is_ready(),通知ORB一切準(zhǔn)備就緒。
表1-4是Server類,它向ORB登記了ORBInfo對(duì)象。
表1-4 服務(wù)器類
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類,它實(shí)現(xiàn)了接口及五個(gè)幫助方法。
表1-5:ORBQuery類
import java.util.*;
class ORBQuery extends ORBQuery._sk_ORBInfo {
String[][] ORBVendors =
{{"PowerBroker","Orbix","VisiBroker","ComponentBroker","
Solaris NEO"},
{"Expersoft Corp.","Iona Technologies","Visigenic Software",
"IBM","Sun"},
{"OLE and ActiveX Bridges; Windows95/NT;
Solaris; HP-UX; AIX; JDK 1.0.2",
"Windows95/NT, MVS, OS/2, QNX, VxWorks, Solaris, HP-UX,
Irix, AIX, Digital UNIX, OLE Bridge",
"Windows95/NT, Sun OS, Solaris, HP-UX, AIX, Irix",
"Windows95/NT, Solaris, HP-UX, AIX, OS/390, OS/2, AS/400",
"Solaris (Client & Server), Windows95/NT (client), JDK 1.0.2"},
{"C++, Java", "Java, Smalltalk, Ada95, C++", "Java, C++",
"Java, C++", "Java, C++"},
{"http://www.expersoft.com", "http://www.iona.com",
"http://www.visigenic.com",
"http://www.software.ibm.com/ad/cb", "http://www.sun.com/solaris/neo/solaris_neo/index.html"}};
ORBQuery(String name) {
super(name);
}
public java.lang.String GetName(int index)
{
String Name;
Name = ORBVendors[index][0];
return Name;
}
public java.lang.String GetVendor(int index)
{
String Vendor;
Vendor = ORBVendors[index][1];
return Vendor;
}
public java.lang.String GetOS(int index)
{
String OS;
OS = ORBVendors[index][2];
return OS;
}
public java.lang.String GetLanguages(int index)
{
String Languages;
Languages = ORBVendors[index][3];
return Languages;
}
public java.lang.String GetURL(int index)
{
String URL;
URL = ORBVendors[index][4];
return URL;
}
}
至此,我們已經(jīng)寫好了所有服務(wù)器方必需的代碼,下一步的工作是創(chuàng)建客戶小應(yīng)用,初始化客戶ORB,進(jìn)而擊活并調(diào)用剛剛生成的服務(wù)器對(duì)象。
4.創(chuàng)建CORBA小應(yīng)用
正如服務(wù)器對(duì)象要向服務(wù)器ORB登記一樣,客戶端小應(yīng)用或應(yīng)用程序需要向客戶機(jī)ORB登記。當(dāng)要獲得遠(yuǎn)程CORBA對(duì)象時(shí),客戶機(jī)采用了一種間接的方法,它通知客戶機(jī)ORB其意圖,由ORB負(fù)責(zé)ORB到ORB的通訊。這種請(qǐng)求方式由下面兩行代碼實(shí)現(xiàn)(在VisiBrokerforJava中):
//初始化ORB(使用applet)
org.omg.CORBA.ORBorb=org.omg.CORBA.ORB.init(this);
//檢索applet要調(diào)用的ORBInfo接口對(duì)象
ORBInfoQuery=ORBQuery.ORBInfoHelper.bind(orb,"ORBInfo");
執(zhí)行了bind()方法調(diào)用之后,我們的ORBInfoQuery本地變量與服務(wù)器的ORBInfo對(duì)象綁在一起。這一操作完成之后,我們就可以調(diào)用幫助方法來實(shí)現(xiàn)客戶端小應(yīng)用。記住,盡管示例中我們完全使用了Java語言,但實(shí)際上,服務(wù)器對(duì)象也可以用其他語言來實(shí)現(xiàn),如:COBOL、C++、Ada和Smalltalk。
5.編寫簡(jiǎn)單的CORBA服務(wù)的一般流程
(以Java2為例):
l編寫所需要的接口IDL文件。
nfoo.idl
module foo{
interface function{
float square_root(in float number);
}
}
l用idltojava編譯idl文件。
nidltojava –fno-cpp foo.idl
l用Javac編譯所產(chǎn)生的類。
njavac ~\*.java
l生成實(shí)現(xiàn)類。
n(functions.java) functinosImpl.java
l生成實(shí)現(xiàn)服務(wù)器。
nfooServer.java
l生成客戶機(jī)應(yīng)用程序(或小程序)。
nfooClient.java
l編譯實(shí)現(xiàn)服務(wù)器和客戶機(jī)代碼。
njavac functionsImpl.java fooServer.java fooClient.java
l啟動(dòng)命名服務(wù)應(yīng)用程序tnameserv。
ntnameserv –ORBInitialPort 1080
l啟動(dòng)服務(wù)器(用命名服務(wù)注冊(cè))。
njava fooServer –ORBInitialPort 1080
l啟動(dòng)客戶機(jī)。
njava fooClient –ORBInitialPort 1080
6.結(jié)論
與單純的Java小應(yīng)用相比,創(chuàng)建CORBAJava應(yīng)用稍顯復(fù)雜。事實(shí)上,這同樣比用RMI創(chuàng)建純粹的Java分布式對(duì)象應(yīng)用要難一些。但是,CORBA和Java的聯(lián)合,所創(chuàng)建的應(yīng)用程序功能更為強(qiáng)大,更具可擴(kuò)充性,這是單純用JDK開發(fā)所無法比擬的。另外,現(xiàn)實(shí)是企業(yè)界很少使用Java應(yīng)用程序。CORBA是兩全其美的選擇,一方面它允許開發(fā)者利用已有的代碼保護(hù)投資,另一方面又可以充分發(fā)揮Java編程語言的優(yōu)勢(shì)。
5.4JSP與CORBA技術(shù)的結(jié)合使用
若想實(shí)現(xiàn)Web上分布式客戶機(jī)/服務(wù)器模式的應(yīng)用程序,可以選擇多種不同的技術(shù)。但是,對(duì)于必須服務(wù)于大量用戶的應(yīng)用,我們認(rèn)為應(yīng)該首選CORBA,因?yàn)樗哂锌蓴U(kuò)展性和業(yè)界廣泛的支持。由于CORBA的強(qiáng)健性可以提高Java編程語言的性能,利用已有的基于標(biāo)準(zhǔn)的技術(shù),Java開發(fā)者可以編寫出功能強(qiáng)大的Web應(yīng)用程序。
想要對(duì)已有的Web軟件資源加以利用,或是編寫真正功能強(qiáng)大的應(yīng)用程序,使Internet/Intranet成為通信主干,所使用的技術(shù)必須具有以下特性:
·支持現(xiàn)有的C、C++和COBOL代碼
·支持Java,以建立具有可移值性、平臺(tái)獨(dú)立性的面向?qū)ο蟮膽?yīng)用程序
·商業(yè)中立性,只有這樣,應(yīng)用程序才易于維護(hù),且不會(huì)被時(shí)間淘汰。
·可擴(kuò)充性,能夠支持大量用戶
·它應(yīng)該被多種平臺(tái)所支持,而不是固定于某種平臺(tái)之上。
·開發(fā)模型應(yīng)該是面向?qū)ο蟮模ㄒ驗(yàn)镺OP有許多固有優(yōu)勢(shì))
·端到端的安全性
·廣泛的業(yè)界支持
這種技術(shù)便是以CORBA為最佳。
Servlets是JAVA 2.0中新增的一個(gè)全新功能,它是運(yùn)行在請(qǐng)求/面向請(qǐng)求服務(wù)器上的模塊,比如一個(gè)Java-enabled web 服務(wù)器, 和類似這樣的延伸場(chǎng)合. 例如, 一個(gè)servlet可以從一個(gè)HTML訂單表中獲取數(shù)據(jù)然后用一些商業(yè)上的算法來更新公司相應(yīng)的訂單數(shù)據(jù)庫。
也就是說:servlet能夠象CGI腳本一樣擴(kuò)展WEB服務(wù)器功能,但是servlet占用很少密集資源,有很多用CGI腳本編制的一些站點(diǎn)由于訪問量劇增,性能迅速下降,這是CGI腳本一個(gè)缺點(diǎn)。同時(shí)由于servlet是用java編寫的,因此是跨平臺(tái)的?梢赃@樣說,實(shí)際servlet是電子商務(wù)真正的開始。
跨平臺(tái)的Java Servlet與跨語言的corba的強(qiáng)強(qiáng)聯(lián)合,使得開發(fā)者可以編寫出功能強(qiáng)大的Web應(yīng)用程序。