JAVA---RMI详解1

一、RMI简介

The Java Remote Method Invocation (RMI)允许运行在一台虚拟机上的对象调用运行在另一台虚拟机上的对象中的方法。RMI使用stubs and skeletons (存根和骨架)架构来和远程对象(Remote Object)沟通

二、相关术语介绍

1、RMIRegistry

RMI注册表,RMIServer负责将stubs(存根)注册到RMIRegistry,RMIClient从RMIRegistry获取stubs(存根)。

2、RMIServer

RMIServer负责创建Remote Object(远程对象),并将之导出到 JAVA RMI runtime,远程对象必须被导出到JAVA RMI runtime,这样该远程对象才能接受远程调用。

3、RMIClient

RMIClient负责发起远程方法调用。

4、Remote Object

RMIServer负责创建Remote Object(远程对象),并将之导出到 JAVA RMI runtime。

5、stubs(存根)

JAVA RMI使用一种特殊的类(这些类被称作stubs)来发起对远程对象的方法调用。远程对象导出的结果形成了这种特殊的类(stubs)。stubs与Remote Object实现的接口是一样的,并且包含hostname和port,hostname和port与Remote Object能够形成对应关系。stubs实例实际上就是Remote Object(远程对象)的引用

6、skeletons

三、RMI架构

RMI远程调用架构图如下:

1、首先创建远程对象接口,该接口必须继承java.rmi.Remote接口,该接口中的方法必须抛出java.rmi.RemoteException异常;

2、远程对象(Remote Object)必须实现该接口,以及其中所包含的方法

3、必须启动rmiregistry,有两种启动方式:
使用rmiregistry工具
windows

powershell 复制代码
C:\Users\love1>start rmiregistry  2001

C:\Users\love1>

linux

bash 复制代码
[yiifung@master02 ~]$ rmiregistry -J-D=java.rmi.server.codebase=/home/yiifung   2001 &
[1] 4980

java代码实现

java 复制代码
LocateRegistry.createRegistry(2001); //Registry使用2001端口,默认启动端口1099

4、获取 rmiregistry实例对象

java 复制代码
Registry registry = LocateRegistry.getRegistry("127.0.0.1", 20001); //获取Registry

5、将远程对象实例导出,并返会该远程对象的stubs实例(the remote object's stub instance)

java 复制代码
 HelloRemote stub = (HelloRemote) UnicastRemoteObject.exportObject(helloRemote, 1);

6、客户端会请求一个到该 Remote Object (远程对象)的引用,其实远程对象的stubs实例就是对该远程对象的引用

四、rmic详解

rmic用于生成静态存根,但是该方法已被弃用,java现在使用动态生成的存根来取代

powershell 复制代码
rmic  rmit.HelloRemoteImpl
PS C:\Users\love1\Documents\technology\java\project> rmic  rmit.HelloRemoteImpl
警告: 为 JRMP 生成和使用骨架及静态存根
已过时。骨架不再必要, 而静态存根
已由动态生成的存根取代。建议用户
不再使用rmic来生成骨架和静态存根。
请参阅 java.rmi.server.UnicastRemoteObject 的文档。
PS C:\Users\love1\Documents\technology\java\project>

生成的静态存根类如下

powershell 复制代码
PS C:\Users\love1\Documents\technology\java\project> tree rmit  /F
卷 Windows 的文件夹 PATH 列表
卷序列号为 E451-5551
C:\USERS\LOVE1\DOCUMENTS\TECHNOLOGY\JAVA\PROJECT\RMIT
    HelloRemote.class
    HelloRemote.java
    HelloRemoteImpl.class
    HelloRemoteImpl.java
    HelloRemoteImpl_Stub.class

没有子文件夹

PS C:\Users\love1\Documents\technology\java\project>
相关推荐
lulu121654407832 分钟前
OpenRouter Fusion 多模型融合架构深度拆解:预算级模型组团打平 Fable 5,多模型协作才是 AGI 的正确打开方式?
java·人工智能·架构·ai编程·agi
雨辰AI37 分钟前
生产级实测:SpringBoot3 + 达梦数据库接口从 200ms 优化至 20ms 完整调优指南
java·数据库·spring boot·后端·政务
(Charon)1 小时前
【C++ 面试高频:内存管理、RAII 和智能指针详解】
java·开发语言·word
凡人叶枫1 小时前
Effective C++ 条款39:明智而审慎地使用 private 继承
java·数据库·c++·嵌入式开发
轻刀快马2 小时前
跨越软硬件的共鸣(二):从 Cache 写策略看 Redis 与 DB 的一致性博弈
java·开发语言·redis·计算机组成原理
折哥的程序人生 · 物流技术专研2 小时前
Java 23 种设计模式:从踩坑到精通 | 装饰器模式 —— 比继承更灵活的扩展方式,你用过吗?
java·装饰器模式·java面试·结构型模式·java设计模式·javaio·从踩坑到精通
lili00122 小时前
2026 企业 AI 选型新范式:OpenRouter Fusion 证明多模型融合性价比远超单模型,企业该如何重构技术栈? - 微元算力(weytoken)
java·人工智能·python·重构·ai编程
shushangyun_2 小时前
汽车服务行业B2B平台+AI解决方案哪家专业:2026年最新测评
java·运维·网络·数据库·人工智能·汽车
gCode Teacher 格码致知2 小时前
Javascript技术:CSS 中rem、vh 和 px各有其最佳适用场景-由Deepseek产生
开发语言·javascript·css
A.说学逗唱的Coke2 小时前
【大模型专题】Spring AI Alibaba × Skill 整合实战:让 AI 真正“会干活
java·人工智能·spring