JavaEE知识整理系列(三)RMI
来源:互联网 发布:算法导论16.1 2 编辑:程序博客网 时间:2024/05/17 22:38
远程方法调用(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通讯。
- JavaEE知识整理系列(三)RMI
- JavaEE知识整理系列(三)RMI .
- JavaEE知识整理系列(二)EJB
- JavaEE知识整理系列(四)JMX
- JavaEE知识整理系列(五)JNDI
- JavaEE知识整理系列(六)JMS
- JavaEE知识整理系列(七)CORBA
- JavaEE知识整理系列(二)EJB .
- JavaEE知识整理系列(四)JMX .
- JavaEE知识整理系列(五)JNDI .
- JavaEE知识整理系列(六)JMS .
- JavaEE知识整理系列(一)JavaEE概述
- JavaEE知识整理系列(一)JavaEE概述 .
- JavaEE知识整理系列(八)Web Service
- matlab知识整理(三)
- javaEE之远程方法调用(RMI)
- 流媒体传输知识整理(三)
- (整理篇三)Android知识图谱
- 卫星拍下的正在飞行的飞机(在帝都郊区啊!!!)
- 生活在深圳我们需要的不是叹息与感概
- Java进行zip包压缩/解压
- 配置JDK环境
- Servlet服务器中_sql文件连接数据库Connection接口
- JavaEE知识整理系列(三)RMI
- 图片翻转 和旋转
- linux 复制文件夹内所有文件到另一个文件夹
- java位运算
- Key event 分发流程研究心得
- 关于产品的一些思考——腾讯之CXO决赛
- JavaEE知识整理系列(四)JMX
- Sql Server临时表的作用域
- cocos2dx 中锚点