Java远程方法调用(Remote Method Invocation,RMI);Dubbo、spring远程原理

GoogleVip8 1年前 ⋅ 723 阅读

Java远程方法调用(Remote Method Invocation,RMI)

一、什么是RMI

1、概念

RMI又叫做远程方法调用。在java中表示一台java虚拟机上的程序调用另外一台java虚拟机上的程序。QQ里面有一个远程控制别人电脑,其实就是基于这个原理。这一篇只是讲解一些基础的使用,如果深入进去,你也可以写一个远程控制器,去控制别人的电脑。

2、原理

既然是一个java虚拟机上的程序调用另外一台java虚拟机上的程序,那肯定是要经过通信的,通信的话就要遵循通信协议,使用通信方法。java提供了Socket来进行通信,封装了底层的通信协议。于是RMI就是通过socket进行通信的。我们画一张图来看一下整个RMI调用的流程。

u=4222898894,1109122665&fm=173&app=49&f=JPEG.jpeg

这就是整个流程,我是使用画图工具画的,不好看还请见谅。这里面涉及到了四个名词client、server、Stub、Skeleton。我们先对这4个名词先进性解释一下,然后再来看整个流程。

(1)名词介绍

第一个:client和server

意思就是客户端和服务器嘛,也就是一个调用方法者,一个被调用者,这个很好理解。

第二个:Stub和Skeleton

想要理解这俩名词的含义,我们可以举个例子,比如说我们想要找一位大老板帮忙,首先我们不直接去,找一个代理,这个代理先找到大老板的管家,通过管家再认识大老板。我们可以画一张图。 u=1477581337,3892192506&fm=173&app=49&f=JPEG.jpeg

上面就是涉及到的几个名词含义。很容易理解。下面我们就真正开始介绍一下流程。

(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接口

package Remote;

import java.rmi.Remote;
import java.rmi.RemoteException;

/**
 * @author MT
 * @program: gcyl-all
 * @Description:
 * @Created by MT on 2019-09-02 09:46
 */
public interface WeacherService extends Remote {

    /**
     * 测试远程接口调用
     *
     * @return
     */
    String test() throws RemoteException;
}

2、创建server接口实现类

package Remote;


import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;

/**
 * @author MT
 * @program: gcyl-all
 * @Description:
 * @Created by MT on 2019-09-02 09:48
 */
public class WeacherServiceImpl extends UnicastRemoteObject implements WeacherService {

    protected WeacherServiceImpl() throws RemoteException {
        super();
    }

    @Override
    public String test() throws RemoteException {
        System.out.println("连接到远程测试了");
        return "远程测试成功";
    }
}

3、server创建注册表并注册服务

package Remote;

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;

/**
 * @author MT
 * @program: gcyl-all
 * @Description:
 * @Created by MT on 2019-09-02 09:50
 */
public class RMIService {

    public static void main(String[] args) {

        try {
            // 创建一个服务
            WeacherService weacherService = new WeacherServiceImpl();
            // 生成注册表
            LocateRegistry.createRegistry(8330);
            // 把代理绑定到注册表上发布:weather是暗号
            Naming.rebind("rmi://192.168.1.163:8330/weather", weacherService);

            System.out.println("开启远程测试成功");
        } catch (RemoteException e) {
            e.printStackTrace();
        } catch (MalformedURLException e) {
            e.printStackTrace();
        }
    }
}

4、创建client,获取注册表并调用服务

package Remote;

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;

/**
 * @author MT
 * @program: gcyl-all
 * @Description:
 * @Created by MT on 2019-09-02 09:52
 */
public class RMICilent {

    public static void main(String[] args) {
        try {
            System.out.println("开始远程测试");
            WeacherService weacherService =
                    (WeacherService) Naming.lookup("rmi://192.168.1.163:8330/weather");
            String test = weacherService.test();
            System.out.println(test);
        } catch (NotBoundException e) {
            e.printStackTrace();
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (RemoteException e) {
            e.printStackTrace();
        }
    }
}

这就是整个基本流程,其实如果我们学过webservice的话应该都会很熟悉这个过程,不过webservice更加的麻烦。

先执行RMIService,在执行RMIClient就能看到调用结果了

两台电脑更加明显哦!!!

快动手试一试吧!

三、总结

RMI的用途可以说是超级广泛了,比如说Dubbo、Spring。具体如何使用这里就不再描述了,不过java提供的RMI还是很少用到的,如果我们知道它的原理,可以完成一些在RMI之上的一些功能。比如说远程控制电脑。


全部评论: 0

    我有话说: