java远程调用之RMI(终于可以自己写代码控制别人电脑了)
之前在研究生课程当中学了分布式系统这门课,而且还是自己的导师讲的这门课,在课堂上迷迷糊糊的晃悠了一学期,除了听见几个名词,也没太多印象。正好这几天用到远程过程调用,使用的是gRPC,想到之前上课听过,于是把这块的知识从书到教程好好地补充了一下。
本篇文章尽量不啰嗦,它的重要性自己可以私下了解一下。
一、什么是RMI
1、概念
RMI又叫做远程方法调用。在java中表示一台java虚拟机上的程序调用另外一台java虚拟机上的程序。QQ里面有一个远程控制别人电脑,其实就是基于这个原理。这一篇只是讲解一些基础的使用,如果深入进去,你也可以写一个远程控制器,去控制别人的电脑 。
2、原理
既然是一个java虚拟机上的程序调用另外一台java虚拟机上的程序,那肯定是要经过通信的,通信的话就要遵循通信协议,使用通信方法。java提供了Socket来进行通信,封装了底层的通信协议。于是RMI就是通过socket进行通信的。我们画一张图来看一下整个RMI调用的流程。
这就是整个流程,我是使用画图工具画的,不好看还请见谅。这里面涉及到了四个名词client、server、Stub、Skeleton。我们先对这4个名词先进性解释一下,然后再来看整个流程。
(1)名词介绍
第一个:client和server
意思就是客户端和服务器嘛,也就是一个调用方法者,一个被调用者,这个很好理解。
第二个:Stub和Skeleton
想要理解这俩名词的含义,我们可以举个例子,比如说我们想要找一位大老板帮忙,首先我们不直接去,找一个代理,这个代理先找到大老板的管家,通过管家再认识大老板。我们可以画一张图。
上面就是涉及到的几个名词含义。很容易理解。下面我们就真正开始介绍一下流程。
(2)RMI流程
第一步:客户端请求代理
第二步:Stub编码处理消息
第三步:消息传输
第四步:到达管家skeleton并处理信息
第五步:管家skeleton把信息提交给server
第六步:server接收到请求
第七步:server把请求的结果给管家
第八步:管家skeleton把结果转交给stub
第九步:代理Stub对结果解码
第十步:Stub把解码的结果交给client。
以上就是RMI的原理和流程。
二、代码实现
以上我们把RMI的概念以及原理介绍完了,最主要的还是如何去使用。使用的时候也有一个开发流程。
1、编写server接口,继承Remote。 2、编写server接口实现类,继承UnicastRemoteObject 类。 3、server创建一个注册表,指定端口。 4、server往注册表中注册server服务。 5、client获取注册表调用远程server方法。
这就是整个基本开发流程。在这里我们举个例子,客户端想要查询天气。调用某个城市,server就能返回某个城市的天气信息。(你可以在两台电脑上编写代码,更能体会到其思想)
1、创建server接口
2、创建server接口实现类
在这里只提供了两个城市,真实情况下肯定不是这样的。需要到数据库里面获取天气信息。
3、server创建注册表并注册服务
4、创建client,获取注册表并调用服务
这就是整个基本流程,其实如果我们学过webservice的话应该都会很熟悉这个过程,不过webservice更加的麻烦。下面我们验证一下。首先输入“安”发现没有就返回错误,然后再修正。
三、总结
RMI的用途可以说是超级广泛了,比如说Dubbo、Spring。具体如何使用这里就不再描述了,不过java提供的RMI还是很少用到的,如果我们知道它的原理,可以完成一些在RMI之上的一些功能。比如说远程控制电脑。
java远程调用之RMI(自己可以写代码控制别人电脑)
之前在研究生课程当中学了分布式系统这门课,而且还是自己的导师讲的这门课,在课堂上迷迷糊糊的晃悠了一学期,除了听见几个名词,也没太多印象。正好这几天用到远程过程调用,使用的是gRPC,想到之前上课听过,于是把这块的知识从书到教程好好地补充了一下。
本篇文章尽量不啰嗦,它的重要性自己可以私下了解一下。
一、什么是RMI
1、概念
RMI又叫做远程方法调用。在java中表示一台java虚拟机上的程序调用另外一台java虚拟机上的程序。QQ里面有一个远程控制别人电脑,其实就是基于这个原理。这一篇只是讲解一些基础的使用,如果深入进去,你也可以写一个远程控制器,去控制别人的电脑 。
2、原理
既然是一个java虚拟机上的程序调用另外一台java虚拟机上的程序,那肯定是要经过通信的,通信的话就要遵循通信协议,使用通信方法。java提供了Socket来进行通信,封装了底层的通信协议。于是RMI就是通过socket进行通信的。我们画一张图来看一下整个RMI调用的流程。
这就是整个流程,我是使用画图工具画的,不好看还请见谅。这里面涉及到了四个名词client、server、Stub、Skeleton。我们先对这4个名词先进性解释一下,然后再来看整个流程。
(1)名词介绍
第一个:client和server
意思就是客户端和服务器嘛,也就是一个调用方法者,一个被调用者,这个很好理解。
第二个:Stub和Skeleton
想要理解这俩名词的含义,我们可以举个例子,比如说我们想要找一位大老板帮忙,首先我们不直接去,找一个代理,这个代理先找到大老板的管家,通过管家再认识大老板。我们可以画一张图。
上面就是涉及到的几个名词含义。很容易理解。下面我们就真正开始介绍一下流程。
(2)RMI流程
第一步:客户端请求代理
第二步:Stub编码处理消息
第三步:消息传输
第四步:到达管家skeleton并处理信息
第五步:管家skeleton把信息提交给server
第六步:server接收到请求
第七步:server把请求的结果给管家
第八步:管家skeleton把结果转交给stub
第九步:代理Stub对结果解码
第十步:Stub把解码的结果交给client。
以上就是RMI的原理和流程。
二、代码实现
以上我们把RMI的概念以及原理介绍完了,最主要的还是如何去使用。使用的时候也有一个开发流程。
1、编写server接口,继承Remote。 2、编写server接口实现类,继承UnicastRemoteObject 类。 3、server创建一个注册表,指定端口。 4、server往注册表中注册server服务。 5、client获取注册表调用远程server方法。
这就是整个基本开发流程。在这里我们举个例子,客户端想要查询天气。调用某个城市,server就能返回某个城市的天气信息。(你可以在两台电脑上编写代码,更能体会到其思想)
1、创建server接口
2、创建server接口实现类
在这里只提供了两个城市,真实情况下肯定不是这样的。需要到数据库里面获取天气信息。
3、server创建注册表并注册服务
4、创建client,获取注册表并调用服务
这就是整个基本流程,其实如果我们学过webservice的话应该都会很熟悉这个过程,不过webservice更加的麻烦。下面我们验证一下。首先输入“安”发现没有就返回错误,然后再修正。
三、总结
RMI的用途可以说是超级广泛了,比如说Dubbo、Spring。具体如何使用这里就不再描述了,不过java提供的RMI还是很少用到的,如果我们知道它的原理,可以完成一些在RMI之上的一些功能。比如说远程控制电脑。
相关问答
Linux终端常用远程连接工具有哪些?
先给大家介绍下面几款常用的Linux终端远程连接工具,欢迎补充!1、xshell介绍:xshell是一个非常强大的安全终端模拟软件,它支持SSH1,SSH2,以及Windows平台...
苹果手机可以远程控制吗?
苹果手机可以远程控制,只要对方也有远控装置就行。远控,既远程控制,是在网络上由一台电脑,远距离去控制另一台电脑的技术,这里的远程不是字面意思的远距离...
苹果手机可以远程控制吗?
苹果手机可以远程控制,只要对方也有远控装置就行。远控,既远程控制,是在网络上由一台电脑,远距离去控制另一台电脑的技术,这里的远程不是字面意思的远距离...
如何将jenkins部署到远程服务器?
jenkins部署到远程服务器上需要以下步骤:1、配置远程服务器到jenkins,在系统管理-->系统配置中配置PublishoverSSH,如PublishoverSSH没有安装,要...
java代码如何打开远程资源管理器?或者查找出远程驱动器并且...
importjava.io.File;publicclassTest{publicstaticvoidmain(String[]args)throwsException{/...
电脑控制android设备(手机、平板)的开关机指令是什麽?比如ad...
首先下载电脑版和手机版远程控制软件,分别安装接着我们需要注册一下,在电脑端注册方便,注册激活之后开始登陆用注册的账号,分别登陆电脑端和手机端软件,在手机...
java服务器程序加密,如何做?
目前常见的所谓java编译代码加密基本都是可破解加密,并不能真正的实现加密,因为java是开源的,使用密码加密必然存在运行时解密,只是增加了下解密难度而已,...
Java语言有什么特点?
Java是一种面向对象的高级程序设计语言,被广泛应用在IT项目开发中,它主要有下面这几个特点:1.强大的跨平台性Java之所以如此受欢迎,其中最重要的原因之一就...
对于Python编程,如何实现连接Linux虚拟机?有哪些注意事项?
你说的是Python模拟ssh登陆Linux虚拟机,并执行shell命令吧,这里主要用到paramiko这个库,可以完成创建ssh客户端,执行shell命令,并返回执行结果,下面我简单...>...
怎么远程连接外网的数据库-ZOL问答
最近测试过程中,老需要远程登录到外网的一套服务器上面做测试,但是因为不少开发GG也在上面部署新的代码,所以互相T来T去的,着实比较痛苦和纠结。。今天终于找...