`
suoyihen
  • 浏览: 1356352 次
文章分类
社区版块
存档分类
最新评论

使用Java进行CORBA编程-JacORB-Event Service

 
阅读更多

CORBA的Event Service提供了一种分发事件通知的方式。
Event Servcie的Event Channel从一个Supplier那里得到事件,发送到一个或多个Consumer那里。
事件可以用push的方式发送,也可以用pull的方式发送,也可以混合push和pull。

Event Service的实现可以看JacORB安装目录下的\idl\omg目录中的IDL文件。
CosEventComm.idl
CosEventChannelAdmin.idl
用类图来表示:

通过这个类图,可以很清晰的得到使用Event Service的步骤。以push mode为例,
Server侧(Supplier)
1)创建一个类,继承自PushSupplierPOA,这个类就是Server侧的Supplier的实现类。
2)创建一个org.jacorb.events.EventChannelImpl的对象,它实现了EventChannel的接口。
然后向NameService注册这个Channel,注册时提供一个Channel名。
3)调用EventChannelImpl对象的for_suppliers()方法,得到一个SupplierAdmin对象。
4)调用SupplierAdmin对象的obtain_push_consumer()方法,得到一个ProxyPushConsumer对象。
5)创建1)中的Supplier的实现类的一个实例。
在上面4)得到的ProxyPushConsumer对象上调用connect_push_supplier()方法,
把Supplier的实现类的实例传给此方法。
6)现在Server侧已经连接到Event Channel,可以调用ProxyPushConsumer对象的push()方法来发送事件通知给Channel了。

Client侧(Consumer)
1)创建一个类,继承自PushConsumerPOA,这个类就是Client侧的Consumer的实现类。
这个类的push()方法,在Event Channel发送事件通知过来的时候会被调用。
在这里添加对事件通知的处理代码。
2)向NameService查询并获得Event Channel的引用(EventChannel对象),查询时需要提供Server侧注册时使用的Channel名。
3)调用EventChannel对象的for_consumers()方法,得到一个ConsumerAdmin对象。
4)调用ConsumerAdmin对象的obtain_push_supplier()方法,得到一个ProxyPushSupplier对象。
5)创建1)中的Consumer的实现类的一个实例。
在上面4)得到的ProxyPushSupplier对象上调用connect_push_consumer()方法,
把Consumer的实现类的实例传给此方法。
6)现在Client侧也已经连接到Event Channel。
这时候如果Server侧(Supplier)发送事件通知,Consumer的实现类的push()方法就会被调用了。

下面提供一个例程,运行此例子需要启动NameService,
启动方法和例程的启动方法见http://blog.csdn.net/fw0124/article/details/7188844

Server代码
1)PushSupplierImpl


2)NewsBCServer


Client代码
1)PushConsumerImpl


2)NewsBCClient



分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics