RPC框架-RMI、RPC和CORBA的区别
关键词:RMI RPC CORBA
简 介:本篇文章重点阐述RMI,附带介绍RPC和CORBA
Java远程方法调用(Java RMI)是一组实现了远程方法调用(rmi)的API。
- java RMI是远程过程调用(RPC)的面向对象版等价概念,它还支持序列化的java类的直接转换以及分布式的垃圾回收(DGC)。
换句话说,java RMI是面向对象的远程调用,属于PRC的一种特例。
RMI的最初实现依赖于java虚拟机的类展现机制,故其只支持从一个JVM到另一个JVM的调用。底层协议只支持java实现就是java远程方法协议(JRMP)
- 为了支持运行在一个非JVM上下文的代码,开发人员后来开发了一个CORBA版本(javax.rmi.CORBA)
![]()
java1.2移除了skeleton对象
下面是一个java RMI的例子:
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
import java.rmi.registry.*;
public class RmiServer extends UnicastRemoteObject implements RmiServerIntf {
public static final String MESSAGE = "Hello World"; public RmiServer() throws RemoteException {
super(0); // required to avoid the 'rmic' step, see below
} public String getMessage() {
return MESSAGE;
} public static void main(String args[]) throws Exception {
System.out.println("RMI server started"); try { //special exception handler for registry creation
LocateRegistry.createRegistry(1099); //一个JVM可以创建一个记录器
System.out.println("java RMI registry created.");
} catch (RemoteException e) {
//do nothing, error means registry already exists
System.out.println("java RMI registry already exists.");
} //Instantiate RmiServer RmiServer obj = new RmiServer(); // Bind this object instance to the name "RmiServer"
Naming.rebind("//localhost/RmiServer", obj);//通过Naming源码可知,rebind方法将RmiServer类型的对象记录到了本地记录器
System.out.println("PeerServer bound in registry");
}
}
import java.rmi.Remote;
import java.rmi.RemoteException; /**
*这个接口需要提供给客户端,也就是提供服务getMessasge()
*/
public interface RmiServerIntf extends Remote {
public String getMessage() throws RemoteException;
}
import java.rmi.Naming; /**
*这个就是客户端
*/
public class RmiClient {
public static void main(String args[]) throws Exception {
//客户端运用了服务器暴露的接口,也叫stub(存根)
RmiServerIntf obj = (RmiServerIntf)Naming.lookup("//localhost/RmiServer");
System.out.println(obj.getMessage());
}
}
***stub,存根,这个词有点像会计学里的术语,想想坐公交、飞机,售票员总会留个底,你持有票据的另一半,这样双方就不会引起误会扯皮了。服务器提供的这个存根也是同理,就相当于一层协议,好让客户端请求服务器提供的服务。当然了,除了核心机制,计算机和现实的售票存在较大差异。
上面的例子,我是运行在了一台机器上,大家可以试试多台机器的远程调用,或者多个JVM之间进行调用。
RPC框架-RMI、RPC和CORBA的区别的更多相关文章
- C# -- 高性能RPC框架:Socean.RPC
简介 Socean.RPC是一个.Net下的高性能RPC框架,框架以高性能.高稳定性为目标,底层基于socket,无第三方库引用,代码简洁,总代码量大约在2000行,框架性能较高,在普通PC上测试,长 ...
- 开源自己实现一个.net rpc框架 - Machete.Rpc
Machete.Rpc Machete.Rpc 是一个轻量级的Rpc(远程过程调用的)框架.底层代理使用了Emit提高了效率,底层通信采用DotNetty框架以提升通信的效率.目前正在逐步完善中. G ...
- RPC框架-通俗易懂的解释
早期单机时代,一台电脑上运行多个进程,大家各干各的,老死不相往来.假如A进程需要一个画图的功能,B进程也需要一个画图的功能,程序员就必须为两个进程都写一个画图的功能.这不是整人么?于是就出现了IPC( ...
- 远程通信机制RPC与RMI的关系
1.RPC RPC(Remote Procedure Call Protocol)远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议.RPC不依赖于具体的网 ...
- RPC 框架
RPC 谁能用通俗的语言解释一下什么是 RPC 框架? - 远程过程调用协议RPC(Remote Procedure Call Protocol) RPC就是要像调用本地的函数一样去调远程函数. 推荐 ...
- Java实现简单的RPC框架
一.RPC简介 RPC,全称为Remote Procedure Call,即远程过程调用,它是一个计算机通信协议.它允许像调用本地服务一样调用远程服务.它可以有不同的实现方式.如RMI(远程方法调用) ...
- Java实现简单的RPC框架(美团面试)
一.RPC简介 RPC,全称为Remote Procedure Call,即远程过程调用,它是一个计算机通信协议.它允许像调用本地服务一样调用远程服务.它可以有不同的实现方式.如RMI(远程方法调用) ...
- Java实现简单RPC框架(转)
一.RPC简介 RPC,全称Remote Procedure Call, 即远程过程调用,它是一个计算机通信协议.它允许像本地服务一样调用远程服务.它可以有不同的实现方式.如RMI(远程方法调用).H ...
- Java 实现简单的 RPC 框架
RPC 简介 RPC,全称为 Remote Procedure Call,即远程过程调用,它是一个计算机通信协议.它允许像调用本地服务一样调用远程服务.它可以有不同的实现方式,而不需要了解底层网络技术 ...
随机推荐
- 彻底理解js中的&&和||
阅读代码时对一行代码很困惑 step > max_step && (step = min_step); 查阅资料后发现它等价于 if (step > max_step) { ...
- HTTP请求报文解剖
转自:https://www.iteye.com/topic/1124408 HTTP请求报文由3部分组成(请求行+请求头+请求体): 下面是一个实际的请求报文: ①是请求方法,GET和POST是最常 ...
- 实现ppt幻灯片播放倒计时
需求:为控制会议时间,采取ppt幻灯片播放倒计时的办法,倒计时5分钟. 分析:用EnumWindows枚举窗口,发现PPT窗口类名有三种:PP12FrameClass.MS-SDIb.screenCl ...
- 指数加权移动平均法(EWMA)
** 本文内容来自于吴恩达深度学习公开课 1.概述 加权移动平均法,是对观察值分别给予不同的权数,按不同权数求得移动平均值,并以最后的移动平均值为基础,确定预测值的方法.采用加权移动平均法,是因为观察 ...
- 11g SPA (sql Performance Analyze) 进行升级测试
注;转自http://ju.outofmemory.cn/entry/77139 11G的新特性SPA(SQL Performance Analyze)现在被广泛的应用到升级和迁移的场景.当然还有一些 ...
- 【vue】vue +element 搭建项目,$createElement使用
语法: 它有三个参数 第一个:html标签名 第二个:配置的数据对象 第三个:内容 应用1:自定义弹窗 html: <el-button type="text" @click ...
- ROS的launch文件
ROS中可以把很多的命令以描述的形式写成launch文件,然后用roslaunch命令执行launch文件.它的使用方法如下: roslaunch [package] [filename.launch ...
- pip 提速方法
Python 包管理软件 pip 在默认情况下,下载安装 Python 包太慢,容易失败.以下给出解决方案. pip install 的选项说明如下: Package Index Options: - ...
- jmeter(二十三)分布式测试
jmeter用了一年多,也断断续续写了一些相关的博客,突然发现没有写过分布式测试的一些东西,这篇博客就介绍下利用jmeter做分布式测试的一些技术点吧,权当参考... 关于jmeter的介绍和元件作用 ...
- Generative Adversarial Nets[CAAE]
本文来自<Age Progression/Regression by Conditional Adversarial Autoencoder>,时间线为2017年2月. 该文很有意思,是如 ...