分布式 RMI和RMIC介绍

本文详细介绍了JavaRMI(RemoteMethodInvocation)的工作原理,包括服务端绑定端口、接口实现,以及客户端通过Registry和Naming进行远程调用的过程。同时讲解了rmic工具的使用,涉及生成stub和skeleton以及处理编码问题的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考文章

java RMI原理详解-优快云博客icon-default.png?t=N7T8https://blog.youkuaiyun.com/xinghun_4/article/details/45787549?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522170195091016800197098183%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=170195091016800197098183&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~top_positive~default-1-45787549-null-null.142^v96^pc_search_result_base5&utm_term=rmi&spm=1018.2226.3001.4187远程接口-远程接口实现类-服务段-客户端

服务端绑定端口号和接口

someInterFace h=new someimpl();//output interface's function
//SomeServer h=new SomeServer();//output server's function
Registry registry=LocateRegistry.createRegistry(8856);
registry.bind("hello",h);

客户端绑定端口和使用函数

someInterFace hello=(someInterFace)Naming.lookup("rmi://localhost:8856/hello");
System.out.println(hello.sayHello("client1"));

以及:

服务端运行函数,实现函数体,返回的函数值传递到客户端---意思是客户端仅仅得到函数值

rmic介绍:rmic 为远 程 对 象生成 stub 和 skeleton。

rmic - Java RMI Stub 编译器-优快云博客icon-default.png?t=N7T8https://blog.youkuaiyun.com/yyg_5106/article/details/83281551?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522170195236916800225522491%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=170195236916800225522491&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduend~default-2-83281551-null-null.142^v96^pc_search_result_base5&utm_term=rmic&spm=1018.2226.3001.4187

打开cmd,然后输入类的前一级路径 然后 javac 类name.java(需先有stub和skeleton,意思是最后搞)

用rmic生成

 先将包下所有函数执行一次:javac *.java

编码错误: javac -encoding UTF-8 *.java(需不存在中文字符)

然后 javac *.java

然后退回调用的很多包前 rmic -vcompat all_experience.fenbushi.rmitask.copy.someimpl

或rmic -vcompat D:\joyuri\all_experience\src\all_experience\fenbushi\rmitask\copy\someimpl.java

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值