远程方法调用与分布式系统通信技术解析
1. 远程方法调用(RMI)概述
远程方法调用(Remote Method Invocation,RMI)是 Java 平台用于远程过程调用(RPC)的标准。远程过程调用在概念上与程序内的普通过程调用相同,但它可以通过网络在两个独立进程之间进行。在 RMI 中,有客户端程序和服务器程序,它们可以运行在不同的机器上,或者至少在同一台机器的两个独立进程中。客户端程序调用服务器上的方法,并等待服务器返回结果后再继续正常执行,就像普通的本地方法调用一样。
2. 核心 RPC/RMI 原理
在 RPC 中,要调用远程对象的方法,主要有以下三个步骤:
1. 获取远程对象引用 :必须在远程服务器上查找远程对象,以获得其引用。
2. 参数的编组和解组 :当调用远程引用上的方法时,参数必须编组为可以通过网络发送的字节流。在服务器端,这些参数需要从字节流中解组为原始值,然后传递给相应的方法。
3. 通过公共协议传输数据 :必须定义一个协议来传输和传递这些方法调用和返回结果。需要有参数的标准格式,以及告知服务器要调用哪个对象上的哪个方法的标准。
为了使远程调用看起来像本地调用,存在一个具有相同接口的本地实现,称为存根(stub)。存根本质上是实际实现的代理。当在本地实现或存根上调用方法时,它会执行必要的操作,将方法调用发送到另一台服务器上相同接口的远程实现。存根编组参数并使用公共 RMI 协议通过网络发送它们。服务器端的存根解组参数,然后以正常方法调用的方式将它们传递给实际的远程对象。返回值的处理过
超级会员免费看
订阅专栏 解锁全文
170万+

被折叠的 条评论
为什么被折叠?



