利用动态调用方式实现分布式应用(下)
2007-12-17 11:18
225 查看
利用动态调用方式实现分布式应用(下)
(本文转载自软件工程专家网www.21cmm.com)苏洋
上一讲介绍了利用动态调用方式实现分布式应用时, 客户端动态调用接口(DII)和服务对象动态骨架接口(DSI)的创建,下面用一个具体的例子来说明整个过程。
1. 对象功能描述和系统简要设计
本例仍然模拟电信资费管理业务流程,在服务对象端注册一个电话用户。用户在远程客户端查询该用户本月发生的电话费用。根据对象功能的说明,用UML描述出服务对象需要实现的功能:
getFee() : float
openAccout( string name ) : Agent
2. 服务对象接口定义
根据系统分析结果,用IDL编写出服务对象方法描述程序TeleComm.idl:
module TeleComm
{
interface Agent
{
float getFee();
};
interface AgentManager
{
Account openAccount(in string name);
};
};
3. 接口的实现
(1)Agent接口的实现
public class AgentImpl extends DynamicImplementation
{
//构造AgentImpl类
//get方法在invoke动态调用方法中按名字匹配调用
public synchronized org.omg.CORBA.Object get(String name){
//申请账户金额,生成账户对象
}
public void invoke(org.omg.CORBA.ServerRequest request){
//申请可移植对象适配器
//填写调用参数,提出申请账户请求
}
}
(2)AgentManager接口实现
public class AgentManagerImpl extends DynamicImplementation{
//构造AgentManager类
public void invoke(org.omg.CORBA.ServerRequest request){
//填写调用参数表,向Agent对象提出业务请求,获取Agent对象
//……
}
}
(3)服务器端程序设计
public class Server {
public static void main(String[] args) {
//初始化ORB、申请POA和POA管理器
//申请默认服务对象,激活POA管理器
//等待调用请求
//……
}
(4)客户端程序设计
public class Client {
public static void main(String[] args) {
//初始化ORB,定位Agentmanager对象
//发出调用请求
org.omg.CORBA.Request request=manager ._request(“getFee”);
request.invoke();
//查询返回结果,取得返回值
request.get_response();
//异常处理
//……
}
4. 程序设计及运行环境说明
上述基于动态调用接口和动态骨架接口的程序是基于VisiBroker 4.5.1中间件环境开发的。其他环境下程序的实现方式和运行可能会有所差别。在VisiBroker环境下,按如下方式运行程序:
(1)首先启动VisiBroker Smart Agent事务代理;
(2)启动服务对象程序:vbj Server;
(3)启动客户对象程序:vbj Client。
其中vbj是VisiBroker for Java中的Java代码解释执行程序。读者也可以用Java解释工具java代替,但需要指定VisiBroker中的vbjorb等库。
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=2318
相关文章推荐
- 利用动态调用方式实现分布式应用(上)
- 利用动态调用方式实现分布式应用(下)
- 利用动态调用方式实现分布式应用(上)
- 【远程调用框架】如何实现一个简单的RPC框架(三)优化一:利用动态代理改变用户服务调用方式
- 使用接口的方式调用远程服务 ------ 利用动态调用服务,实现.net下类似Dubbo的玩法。
- python利用字典保存配置实现动态调用模块类方法
- SSH框架利用注解方式实现根据多条件动态分页查询图书信息(传对象)
- 利用动态创建自动化接口实现VB的函数指针调用
- JS跨域调用之JSONP--动态Script标签方式实现跨域
- [WCF-Discovery] 实例演示:如何利用服务发现机制实现服务的“动态”调用?
- Struts2.5使用通配符的方式实现动态方法调用报错
- (转载)Net 下采用GET/POST/SOAP方式动态调用WebService C#实现
- 利用反射,实现动态调用winform窗体(转)
- Net 下采用GET/POST/SOAP方式动态调用WebService C#实现
- JS跨域调用之JSONP--动态Script标签方式实现跨域
- 利用函数指针实现动态库的动态调用——函数指针正向调用法
- JS跨域调用之JSONP--动态Script标签方式实现跨域
- 利用动态代理实现通用存储过程的调用
- [转]Net 下采用GET/POST/SOAP方式动态调用WebService C#实现
- JS跨域调用之JSONP--动态Script标签方式实现跨域(转)