利用動(dòng)態(tài)調(diào)用方式實(shí)現(xiàn)分布式應(yīng)用(下)
(本文轉(zhuǎn)載自軟件工程專家網(wǎng) www.21cmm.com )
蘇洋
上一講介紹了利用動(dòng)態(tài)調(diào)用方式實(shí)現(xiàn)分布式應(yīng)用時(shí), 客戶端動(dòng)態(tài)調(diào)用接口(DII)和服務(wù)對(duì)象動(dòng)態(tài)骨架接口(DSI)的創(chuàng)建,下面用一個(gè)具體的例子來說明整個(gè)過程。
1. 對(duì)象功能描述和系統(tǒng)簡(jiǎn)要設(shè)計(jì)
本例仍然模擬電信資費(fèi)管理業(yè)務(wù)流程,在服務(wù)對(duì)象端注冊(cè)一個(gè)電話用戶。用戶在遠(yuǎn)程客戶端查詢?cè)撚脩舯驹掳l(fā)生的電話費(fèi)用。根據(jù)對(duì)象功能的說明,用UML描述出服務(wù)對(duì)象需要實(shí)現(xiàn)的功能:
getFee() : float
openAccout( string name ) : Agent
2. 服務(wù)對(duì)象接口定義
根據(jù)系統(tǒng)分析結(jié)果,用IDL編寫出服務(wù)對(duì)象方法描述程序TeleComm.idl:
module TeleComm
{
interface Agent
{
float getFee();
};
interface AgentManager
{
Account openAccount(in string name);
};
};
3. 接口的實(shí)現(xiàn)
(1)Agent接口的實(shí)現(xiàn)
public class AgentImpl extends DynamicImplementation
{
//構(gòu)造AgentImpl類
//get方法在invoke動(dòng)態(tài)調(diào)用方法中按名字匹配調(diào)用
public synchronized org.omg.CORBA.Object get(String name){
//申請(qǐng)賬戶金額,生成賬戶對(duì)象
}
public void invoke(org.omg.CORBA.ServerRequest request){
//申請(qǐng)可移植對(duì)象適配器
//填寫調(diào)用參數(shù),提出申請(qǐng)賬戶請(qǐng)求
}
}
(2)AgentManager接口實(shí)現(xiàn)
public class AgentManagerImpl extends DynamicImplementation{
//構(gòu)造AgentManager類
public void invoke(org.omg.CORBA.ServerRequest request){
//填寫調(diào)用參數(shù)表,向Agent對(duì)象提出業(yè)務(wù)請(qǐng)求,獲取Agent對(duì)象
//……
}
}
(3)服務(wù)器端程序設(shè)計(jì)
public class Server {
public static void main(String[] args) {
//初始化ORB、申請(qǐng)POA和POA管理器
//申請(qǐng)默認(rèn)服務(wù)對(duì)象,激活POA管理器
//等待調(diào)用請(qǐng)求
//……
}
(4)客戶端程序設(shè)計(jì)
public class Client {
public static void main(String[] args) {
//初始化ORB,定位Agentmanager對(duì)象
//發(fā)出調(diào)用請(qǐng)求
org.omg.CORBA.Request request=manager ._request(“getFee”);
request.invoke();
//查詢返回結(jié)果,取得返回值
request.get_response();
//異常處理
//……
}
4. 程序設(shè)計(jì)及運(yùn)行環(huán)境說明
上述基于動(dòng)態(tài)調(diào)用接口和動(dòng)態(tài)骨架接口的程序是基于VisiBroker 4.5.1中間件環(huán)境開發(fā)的。其他環(huán)境下程序的實(shí)現(xiàn)方式和運(yùn)行可能會(huì)有所差別。在VisiBroker環(huán)境下,按如下方式運(yùn)行程序:
(1)首先啟動(dòng)VisiBroker Smart Agent事務(wù)代理;
(2)啟動(dòng)服務(wù)對(duì)象程序:vbj Server;
(3)啟動(dòng)客戶對(duì)象程序:vbj Client。
其中vbj是VisiBroker for Java中的Java代碼解釋執(zhí)行程序。讀者也可以用Java解釋工具java代替,但需要指定VisiBroker中的vbjorb等庫(kù)。
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=2318
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
