java RMI 源码总结(我的理解)

明天早上详细写下两个过程:java

一、初始化过程(服务器)git

二、客户端调用过程(包括客户端流程、调用服务端流程、返回客户端流程)服务器

  • 当客户端经过RMI注册表找到一个远程接口的时候,所获得的实际上是远程接口的一个动态代理对象。
  • 当客户端调用其中的方法的时候,方法的参数对象会在序列化以后,传输到服务器端。
  • 服务器端接收到以后,进行反序列化获得参数对象。
  • 并使用这些参数对象,在服务器端调用实际的方法。
  • 调用的返回值Java对象通过序列化以后,再发送回客户端。
  • 客户端再通过反序列化以后获得Java对象,返回给调用者。
  • 这中间的序列化过程对于使用者来讲是透明的,由动态代理对象自动完成

除了序列化以外,RMI还使用了动态类加载技术代理

  • 当须要进行反序列化的时候,若是该对象的类定义在当前JVM中没有找到,RMI会尝试从远端下载所需的类文件定义
  • 能够在RMI程序启动的时候,经过JVM参数java.rmi.server.codebase来指定动态下载Java类文件的URL。 

具体执行笔记参看代码注释code

相关文章
相关标签/搜索