基于CORBA的分布式程序设计(五)

 

第三章 CORBA程序的编写过程

3.1  开发CORBA的步骤

1. 定义一个IDL

2. IDL接口映射到C++

3. 开发server

4. 开发client

5. 运行名字服务,服务端 和客户端

3.2 CORBA程序的工作流程

  定义你的对象和方法:使用IDL

  Client调用你定义的对象方法

  调用被ORB传递到Server

  Server真正调用你的方法

  结果沿原路返回

3.3 工作流程的一些细节

3.3.1 启动Server,等待来自Client的请求

Server启动后,它首先生成一个POA(potable object adapter)。然后告诉POA他所能提供的服务,即Servant(Server按照IDL定义所实现的每个对象)

ServerPOA处得到每个Servant的引用OR(Object Reference,类似于句柄)

Server把自己提供的服务公布出来,这里有两个办法:

OR转换为一个字符串并输出;

将这个OR绑定到一个简单易理解的名字上,这通过Naming Service完成。

如图所示:

3-1 Server启动并注册服务

3.3.2 Client调用被定义的对象方法

Client通过象Naming Service查询获得要访问的对象的引用OR(object reference),或通过一个IOR字符串获得;

Client通过这个引用调用对象的方法,因为OR中有足够的信息来定位一个对象;

这个调用被传递给ORB

如图所示:

3-2 一个Client发出请求

3.3.3 调用完成

Client端的调用请求通过ORB被传递给正确的Server端的ORB,定位是根据OR实现的;

这个ORB把调用请求交给真正的Server进行处理;

Server又根据OR定位产生这个ORPOA,并把请求传给它;

POA又把请求传给最后真正的Servant,完成调用并返回。

如图所示:

3-3 Server对请求进行服务

 

 

 


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的CORBA程序设计思路,用于输出 "Hello World!" 信息: 1. 定义IDL文件:首先需要定义一个IDL文件,用于定义CORBA对象的接口和方法。在IDL文件中定义一个接口,包含一个返回字符串的方法,例如: ``` interface HelloWorld { string sayHello(); }; ``` 2. 编译IDL文件:使用IDL编译器将IDL文件编译成客户端和服务器端所需的代码。例如,使用omniIDL编译器生成Python代码: ``` omniidl -bpython helloworld.idl ``` 3. 实现服务器端:实现服务器端代码,用于处理客户端请求。在服务器端中实现IDL文件中定义的接口方法,返回 "Hello World!" 字符串。例如,在Python中实现服务器端代码: ``` import CORBA import HelloWorld_idl class HelloWorld_i (HelloWorld_idl.HelloWorld): def sayHello(self): return "Hello World!" orb = CORBA.ORB_init() poa = orb.resolve_initial_references("RootPOA") hello_world = HelloWorld_i() poa.activate_object(hello_world) objref = poa.servant_to_reference(hello_world) print orb.object_to_string(objref) poa._get_the_POAManager().activate() orb.run() ``` 4. 实现客户端:实现客户端代码,用于调用服务器端的方法并输出 "Hello World!" 信息。例如,在Python中实现客户端代码: ``` import CORBA import HelloWorld_idl orb = CORBA.ORB_init() obj = orb.string_to_object("IOR:...") hello_world = obj._narrow(HelloWorld_idl.HelloWorld) if hello_world is None: print "Object reference is not an HelloWorld" else: print hello_world.sayHello() orb.destroy() ``` 5. 启动服务器端:在命令行中执行服务器端代码,例如,在Python中执行: ``` python server.py ``` 6. 运行客户端:在命令行中执行客户端代码,例如,在Python中执行: ``` python client.py ``` 输出应该为 "Hello World!"。 上述步骤是一个简单的CORBA程序设计思路,用于输出 "Hello World!" 信息。实际程序中还需要处理更多的细节,例如ORB的初始化和销毁、异常处理、对象命名和查找等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值