现在的位置: 首页 > 综合 > 正文

JavaEE知识整理系列(三)RMI

2014年02月02日 ⁄ 综合 ⁄ 共 761字 ⁄ 字号 评论关闭

远程方法调用(Remote Methd Invoke RMI)就是调用远程对象的方法,这种调用对调用者而言需要尽可能透明的。

1.        RMI第一阶段(简单处理)

最容易想到的办法就是调用者(客户端)将需要调用的类名或接口、方法名、方法参数类型、方法参数值等参加通过Sokcet以数据结构形式发给实际方法执行者(服务端),服务端通过反射(Reflection)技术,找到响应方法,执行后将结果填充在数据结构中返回。显然这种方法存在可扩展性很小,客户端服务端的耦合性很大等等缺点。【服务端反射】

2.        RMI第二阶段(静态代理)

在第一阶段基础上,抽象出Connection角色并且使用静态代理模式(在代理类通过硬编码指定、实现)实现远程方法调用。这种方法相对于第一有更好的扩展性,但是上述的问题还是无法解决。【服务端反射+静态代理】

3.        RMI第三阶段(动态代理)

在第二阶段基础上使用了动态代理的设计模式,代理类对象通过反射机制动态生成,并且由工厂模式的Factory生产。这种方法显然优与前面的两种,但是真正的使用起来还是比较麻烦。【服务端反射+动态代理(客户端反射代理类)】

4.        RMI第四阶段(RMI框架)

JDK提供的一个完善、简单易用的远程方法调用框架。基本思路和RMI第三阶段一致,只是JDK实现过程有更多的考虑和设计模式的应用,使得编写RMI程序非常简洁、方便。RMI框架为远程对象分别生成了客户端代理(存根Stub)和服务端代理(骨架Skeleton)。【RMI框架】

注:企业级消息总线:Enterprise Message Bus, 简称为EMB,是一种远程分布式环境下的通讯服务。有些分布式应用中,往往使用RMI技术或者封装EJB调用或者直接使用原始Soket来实现EMB通讯。

 

抱歉!评论已关闭.