- 浏览: 528090 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
landerson:
明显就有要求的嘛
ANDROID轻量级JSON序列化和反序列化[转] -
jimode2013:
很不错,就是需要这个方法
多个UIViewController使用addSubView,第二个 UIViewController 不响应旋转[转] -
w11h22j33:
...
[转]NSMutableArray中的自动释放对象让我郁闷了一整天 -
w11h22j33:
UILabel* label = [[UILabel a ...
Iphone开发 -
w11h22j33:
http://mobile.51cto.com/iphone- ...
获得通讯录中联系人的所有属性[转]
http://www.51testing.com/?uid-225738-action-viewspace-itemid-222961
今天刚好对Java RMI进行了简单的学习,也写了一个实例,简单总结一下吧。
1.RMI的基本体系结构
RMI的基本体系结构,概括起来说,由三个抽象层组成:
1、存根/框架层(Stubs/Skeletons Layer)
RMI为我们引入了两种特殊类型的对象,称为存根(Stub)和框架(Skeleton),它们组成了RMI的第一层。
在远程通信的时候,要利用TCP/IP协议,做很多底层数据的打包传输。运用Java分布式计算技术,我们先要把数据或者对象转换成字节流 (byte stream),便于网络传输,这个过程叫汇集(marshaling);当收到远程传来的字节流后,我们要把流信息转换成对象或者数据,这个过程叫解读 (unmarshaling),它与汇集刚好相反。
Stub和Skeleton层位于实际应用程序之下,建立在Proxy(代理)设计方案之上。Stub类的作用是远程服务器实现的代理的角色,Stub是客户方对象;Skeleton类用于帮助对象通过RMI链接与Stub通信,它从链路中读取方法调用的参数,向远程服务实现对象进行调用,接受返回值,然后再把返回值写回到Stub。
2、远程引用层(Remote Reference Layer)
远程引用层定义和支持着RMI连接的调用语义(semantics)。
RMI进行远程访问要用到JRMP(Java Remote Method Protocol,即Java远程方法协议),这一层提供专用于JRMP的RemoteRef对象,它位于java.rmi.server包内,代表着远程对象的一个句柄。RemoteRef使用远程引用来执行远程对象的一个远程方法调用。
3、传输层(Transport Layer)
传输层在JVM之间建立基于流的网络连接,并且负责设置和管理这些连接。这时候,RMI使用一种线级(wire-level)协议进行基于TCP/IP的连接,该协议就是Java远程方法协议(JRMP,即Java Remote Method Protocol)。
在JDK版本1.2开始,JRMP不再需要Skeleton,而是使用reflection来建立与远程服务的连接。为了生成Stub,我们须用rmic。
当前的RMI实现中,传输层建立在TCP/IP基础上,设计用于在客户和服务器之间建立一条连接(即使联网有障碍)。
2.RMI开发的基本步骤
我们使用RMI编写Client/Server模式(客户/服务器)应用程序,包括6个基本步骤:
1) 定义远程接口
2) 实现远程接口
3) 准备远程调用的服务器对象
4) 生成残根Stub(客户代理)和框架Skeleton(服务器实体)
5) 用rmiregistry找到远程对象
6) 运行测试RMI分布式应用
3.实现RMI的简单实例
下面的一些代码时根据网上的资料修改并在本机运行通过的。另外,推荐另一个很简单的例子,就在wikipedia上的这个吧,这个example也非常不错的:
http://en.wikipedia.org/wiki/Java_remote_method_invocation
贴自己的RMI简单实例代码吧:
import java.rmi.Remote;
import java.rmi.RemoteException;
/**
* @className: IHello
* @description: 定义一个远程接口,必须继承Remote接口,其中需要远程调用的方法必须抛出RemoteException异常
* @author: 笑遍世界
* @createTime: 2010-11-9 下午12:33:21
*/
public interface IHello extends Remote {
/**
* 简单的返回“Hello World!"字样
* @return 返回“Hello World!"字样
* @throws java.rmi.RemoteException
*/
public String helloWorld() throws RemoteException;
/**
* 一个简单的业务方法,根据传入的人名返回相应的问候语
* @param someBodyName 人名
* @return 返回相应的问候语
* @throws java.rmi.RemoteException
*/
public String sayHelloToSomeBody(String someBodyName) throws RemoteException;
}
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
/**
* @className: HelloImpl
* @description: RIM远程接口的实现
* @author: 笑遍世界
* @createTime: 2010-11-9 下午12:35:47
*/
public class HelloImpl extends UnicastRemoteObject implements IHello {
/**
*
*/
private static final long serialVersionUID = 1L;
/**
* 因为UnicastRemoteObject的构造方法抛出了RemoteException异常,因此这里默认的构造方法必须写,必须声明抛出RemoteException异常
*
* @throws RemoteException
*/
public HelloImpl() throws RemoteException {
}
/**
* 简单的返回“Hello World!"字样
*
* @return 返回“Hello World!"字样
* @throws java.rmi.RemoteException
*/
public String helloWorld() throws RemoteException {
return "Hello World!";
}
/**
* 一个简单的业务方法,根据传入的人名返回相应的问候语
*
* @param someBodyName 人名
* @return 返回相应的问候语
* @throws java.rmi.RemoteException
*/
public String sayHelloToSomeBody(String someBodyName) throws RemoteException {
return "你好," + someBodyName + "!";
}
}
import java.net.MalformedURLException;
import java.rmi.AlreadyBoundException;
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
/**
* @className: HelloServer
* @description: 创建RMI注册表,启动RMI服务,并将远程对象注册到RMI注册表中。
* @author: 笑遍世界
* @createTime: 2010-11-9 下午12:41:39
*
*/
public class HelloServer {
public static void main(String args[]) {
try {
//创建一个远程对象
IHello rhello = new HelloImpl();
//本地主机上的远程对象注册表Registry的实例,并指定端口为8888,这一步必不可少(Java默认端口是1099),必不可缺的一步,缺少注册表创建,则无法绑定对象到远程注册表上
LocateRegistry.createRegistry(8888);
//把远程对象注册到RMI注册服务器上,并命名为RHello
//绑定的URL标准格式为:rmi://host:port/name(其中协议名可以省略,下面两种写法都是正确的)
Naming.bind("rmi://localhost:8888/RHello",rhello);
// Naming.bind("//localhost:8888/RHello",rhello);
System.out.println(">>>>>INFO:远程IHello对象绑定成功!");
} catch (RemoteException e) {
System.out.println("创建远程对象发生异常!");
e.printStackTrace();
} catch (AlreadyBoundException e) {
System.out.println("发生重复绑定对象异常!");
e.printStackTrace();
} catch (MalformedURLException e) {
System.out.println("发生URL畸形异常!");
e.printStackTrace();
}
}
}
import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;
/**
* @className: HelloClient
* @description: 客户端测试,在客户端调用远程对象上的远程方法,并返回结果。
* @author: 笑遍世界
* @createTime: 2010-11-9 下午01:27:02
*/
public class HelloClient {
public static void main(String args[]){
try {
//在RMI服务注册表中查找名称为RHello的对象,并调用其上的方法
IHello rhello =(IHello) Naming.lookup("rmi://localhost:8888/RHello");
System.out.println(rhello.helloWorld());
System.out.println(rhello.sayHelloToSomeBody("笑遍世界"));
} catch (NotBoundException e) {
e.printStackTrace();
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (RemoteException e) {
e.printStackTrace();
}
}
}
发表评论
-
protobuf/json/xml/binary/Thrift数据交换[转]
2012-04-07 15:24 3112一条消息数据,用protobuf序列化后的大小是json ... -
[转]Ehcache Storage Options
2011-11-02 17:54 1341Ehcache Storage Options ... -
【转】Jackson 框架,轻易转换JSON
2011-11-02 09:36 1148Jackson可以轻松的将Java对象转换成json对象 ... -
【转】RAND算法,FIFO算法,LFU算法,LRU算法,OPT算法
2011-11-02 09:37 2877http://hi.baidu.com/ilovehaley/ ... -
【转】ehcache 让内容一直持久化在磁盘,防止异常丢失
2011-11-01 11:31 2141http://kangzye.blog.163.com/blo ... -
【转】java排序
2011-11-01 11:22 1007Java代码 package sor ... -
【转】使用 EhCache 关于临时目录的一个注意事项
2011-11-01 11:16 1201http://m.oschina.net/question ... -
Friendfeed的MySQL key/value存储【转】
2011-11-01 11:04 1188http://timyang.net/data/friendf ... -
Ehcache使用实例
2011-10-31 17:44 967Ehcache使用实例(一) http://blog.csd ... -
Java日期格式化及其使用例子收集【转】
2011-07-18 16:10 9461 SimpleDateFormat担当重任,怎样格式化都 ... -
应用多线程执行Gets【转】
2011-05-22 11:35 1088http://www.androidres.com/index ... -
DefaultHttpClient进行BasicAuth重复请求的问题【转】
2011-05-22 11:32 3385其实一般的只要设置 ... -
HashMap遍历的两种方式[转]
2011-03-01 18:46 830第一种: Map map = new HashM ... -
Ant搞定全部开发流程【转】
2011-02-27 00:36 1131由于涉及到打包签名,所以在开始全部工作之前,我们先做好签 ... -
JAVA简单的加解密【转】
2011-02-23 23:20 1193http://blog.sina.com.cn/s/blog_ ... -
在Java中使用DES加密解密算法[转]
2011-02-23 23:19 1553import javax.crypto.*;import ... -
利用java反射机制执行类的方法[转]
2011-02-23 22:31 1449Reflection 是 Java 程序开发语言的特征之一, ...
相关推荐
Java RMI实例
JAVARMI实例[文].pdf
JAVA分布式之RMI实例教程网络通信原理[收集].pdf
定义一个实现该接口并扩展了UnicastRemoteObject的类(服务端运行的服务类),这个类将实现给客户端调用的所用方法。 创建服务端供客户端调用的应用程序。 创建客户端RMI调用服务端的应用程序。 启动服务端,再...
java rmi小例子源代码 ,运行Reg.java ,再执行Client客户端代码就能看效果。如果在不同jvm下执行,注意接口定义包路径客服端和服务端必须保持一致。 客服端包含文件有服务端接口的定义文件。
java rmi spring 使用实例,内涵服务端和客户端的源代码,测试可用。
实现通过rmi方式输出hello word,已在俩台机器间通过测试
java rmi 完整的简单例子 包含详细的文档说明
Java编程rmi实例,给出远程方法调用技术在java方面的具体例子。
java RMI开发指南,详细地讲述了java RMI的原理,有具体的实例描述。
rmi的详细例子,rmi的详细用法,一看就懂
JAVA_RMI_实例.pdf
这是一个java远程调用的例子,可运行。
Java RMI实现分布式编程非常好的材料, 里面有几个例子,包含了几个RMI的各个特性. 学习RMI首先实例材料!
RMi java 分布式 开发,包括代码和部署例子
RMI-IIOP Java 源码实例,附有BAT批处理命令,Java EJB初学者可参考学习,EJB的例子。
java rmi 调用实例及详细说明,详细可参见博客:http://blog.csdn.net/fufengrui/article/details/9855865
Java分布式之RMI实例教程,j2ee中的远程调用技术,很好的学习资料。