40、深入理解Java远程方法调用与CORBA技术

深入理解Java远程方法调用与CORBA技术

1. 远程方法调用(RMI)概述

远程方法调用(RMI)是Java平台用于远程过程调用(RPC)的标准。RPC与程序内的普通过程调用概念相似,但它可以跨网络在两个独立进程之间进行。在RPC中,客户端程序和服务器程序通常运行在不同的机器上,或者至少在同一机器的两个独立进程中。客户端调用服务器上的方法,并等待服务器返回结果后再继续执行,就像本地方法调用一样。

2. RMI核心原理

在RPC中,要调用远程对象的方法,通常需要经过以下三个主要步骤:
1. 获取远程对象引用 :需要在远程服务器上查找远程对象。
2. 参数的编组和解组 :当调用远程引用的方法时,参数必须编组为可以通过网络发送的字节流。在服务器端,这些参数需要从字节流中解组为原始值,然后传递给相应的方法。
3. 通过公共协议传输数据 :必须定义一个协议来传输和传递这些方法调用和返回结果。需要有参数的标准格式,以及告知服务器要调用哪个对象上的哪个方法的标准。

为了使远程调用看起来像本地调用,存在一个具有相同接口的本地实现,称为存根(stub)。存根本质上是实际实现的代理。当在本地实现或存根上调用方法时,本地实现会执行必要的操作,将方法调用发送到另一台服务器上相同接口的远程实现。存根会编组参数,并使用通用的RMI协议通过网络发送它们。服务器端的存根则会解组参数,并以正常的方法调用方式将它们传递给实际的远程对象。返回值的处理过程则相反。

3. 编组和解组

在将参数和方法调用通过网

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值