发表于: 2017-12-02 21:46:40
1 813
今天完成的事:
看了rmi,做了一个rmi的小demo。
服务器端新建一个接口和实现类
spring配置
然后是服务器端的rmiservice
然后是客户端
记上服务端的地址
执行客户端client
明天要做的事:
继续理解rmi
问题:
在客户端就可以调用服务端的service的实现,服务端这个放上面应该得是jar包吧?还是web的war包也可以哦?
收获:
初步知道了rmi
RMI(即Remote Method Invoke 远程方法调用)。在Java中,只要一个类extends了java.rmi.Remote接口,即可成为存在于服务器端的远程对象,供客户端访问并提供一定的服务。JavaDoc描述:Remote 接口用于标识其方法可以从非本地虚拟机上调用的接口。任何远程对象都必须直接或间接实现此接口。只有在“远程接口”(扩展 java.rmi.Remote 的接口)中指定的这些方法才可远程使用。
RMI远程调用步骤:
1,客户对象调用客户端辅助对象上的方法
2,客户端辅助对象打包调用信息(变量,方法名),通过网络发送给服务端辅助对象
3,服务端辅助对象将客户端辅助对象发送来的信息解包,找出真正被调用的方法以及该方法所在对象
4,调用真正服务对象上的真正方法,并将结果返回给服务端辅助对象
5,服务端辅助对象将结果打包,发送给客户端辅助对象
6,客户端辅助对象将返回值解包,返回给客户对象
7,客户对象获得返回值
对于客户对象来说,步骤2-6是完全透明的
java RMI的缺点:
1,从代码中也可以看到,代码依赖于ip与端口
2,RMI依赖于Java远程消息交换协议JRMP(Java Remote Messaging Protocol),该协议为java定制,要求服务端与客户端都为java编写
评论