JavaEE知识整理系列(三)RMI

远程方法调用(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通讯。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值