Apusic应用服务器和CORBA的互操作[1]

[入库:2005年8月19日] [更新:2007年3月25日]

本文简介:选择自 rain_2005 的 blog

corba(common object request broker architecture, 公共对象请求代理体系结构)是由omg(对象管理组织,object management group)提出的应用软件体系结构和对象技术规范,被广泛的用来开发分布式系统。apusic应用服务器是以rmi-iiop(remote method invocation internet inter-orb protocol)协议为基础完成分布式的对象的远程访问,因此可以和corba对象进行互相调用。并且,apusic应用服务器还完整的实现了corba-ejb映射规范,能够在多个应用服务器实例和corba客户端之间传播事务、安全等上下文信息。corba和ejb的互操作规范包含以下四个方面:

       ejb接口到corba接口的映射; 


       jndi名字到corba名称服务(cosnaming )的映射;


       ejb和corba之间的事务传播;


       ejb和corba之间的安全传播。


      本文将通过一个范例展示corba客户端访问部署在apusic上的ejb。虽然这是apusic和corba互操作最简单的一个方面,并且不涉及安全和事务的传播,但已经显示了apusic在互操作方面的能力和开发的一般步骤。


      首先介绍一下服务器和客户端的开发运行环境。服务器端的环境为:


        windows 2000 server


        jdk1.4.2


        apusic应用服务器3.0


      客户端的环境为:


        windows 2000 professional 


        jdk1.4.2


        apusic应用服务器完全支持标准的ejb-corba映射,也就是说,ejb的home和remote也是corba对象。我们可以使用jdk提供的rmi编译器rmic -idl为ejb产生corba视图的idl接口。用来定位ejb home接口的jndi(java naming service)被映射成corba naming service,这样,corba客户端就能查找和定位home接口并象corba对象一样使用它们。下图描述了corba客户端访问ejb的一般步骤:这些步骤包括:


        开发并部署ejb; 


        使用rmi编译器rmic -idl为ejb远程接口产生idl; 


        使用corba idl编译器根据客户端的程序语言为客户端产生存根(stub);


        配置ejb服务器使用corba名称服务。apusic缺省就使用corba名称服务作为jndi 服务的提供者;


        corba客户端在corba名称服务中查找和定位ejb;


        corba客户端象访问普通corba对象一样访问ejb;


       首先开发一个ejb模块,编译并部署到apusic应用服务器上。这个例子中的ejb非常简单,是一个stateless session bean,只包含一个业务方法sayhello。


          public java.lang.string sayhello(java.lang.string name) {               


          string result = "hello, " + name;


          system.out.println("invoke sayhello() : " + result);


          return result;


          }


        然后使用rmi编译器rmic -idl为ejb远程接口产生idl:  


       rmic -idl -novaluemethods


      -classpath %apusic_home%/lib/apusic.jar;../ejb/build


      -d idl  samples.ejb.hello  samples.ejb.hellohome


       理论上可以使用任何corba规范支持的程序语言开发corba客户端。本范例展示的是java corba客户端的开发。使用jdk1.4.2提供的idlj编译上一步得到的idl:

本文关键:Apusic应用服务器和CORBA的互操作
  相关方案
Google
 

本站最佳浏览方式为 分辨率 1024x768 IE 6.0(或更高版本的 IE浏览器)

go top