RMI 底层实现

1.

server端代码:
Registry registry= LocateRegistry.createRegistry(8888); //在当前主机的port如8888上创建RMI的Registry注册服务。

registry.bind("RHello",rhello); //注册服务


//或者可以用下边的方式,这样可以指定要注册的服务所在的host地址。
//Naming.bind("rmi://localhost:8888/RHello",rhello);





client端代码:

IHello rhello =(IHello) Naming.lookup("rmi://localhost:8888/RHello");


2. 个人理解:

其实主要是java的rmi接口的具体实现将网络层的相关实现封装起来了。
暴露给程序员的接口主要是 怎么进行注册和查找。
具体的原理实现在底层,和网络技术,计算机底层相关。

为了通过Java的序列化机制来进行传输,远程接口中的方法的参数和返回值,要么是Java的基本类型,要么是远程对象,要么是实现了 Serializable接口的Java类。 当客户端通过RMI注册表找到一个远程接口的时候,所得到的其实是远程接口的一个动态代理对象。当客户端调用其中的方法的时候,方法的参数对象会在序列化之后,传输到服务器端。服务器端接收到之后,进行反序列化得到参数对象。并使用这些参数对象,在服务器端调用实际的方法。调用的返回值Java对象经过序列化之后,再发送回客户端。客户端再经过反序列化之后得到Java对象,返回给调用者。这中间的序列化过程对于使用者来说是透明的,由动态代理对象自动完成。除了序列化之外,RMI还使用了动态类加载技术。当需要进行反序列化的时候,如果该对象的类定义在当前JVM中没有找到,RMI会尝试从远端下载所需的类文件定义。可以在RMI程序启动的时候,通过JVM参数java.rmi.server.codebase来指定动态下载Java类文件的URL。

你可能感兴趣的:(rmi)