企业神奇中间件- RPC之RMI

发布日期:2019-08-24 14:50   来源:未知   阅读:

  emmm....,就是一个专门给 Java 提供的一个远程方法调用,以及进行实现 RPC 的一个 Java API,可以用来远程传输序列化类,以及实现分布式垃圾回收。完全obbqk,咱今天也分成几个阶段来看看RMI,Java Remote Method Invocation,Java 远程方法调用。具体是怎么玩的,怎么去使用它,又是什么原理。

  说走咱就走啊,仅需体验三番钟,你揍会甘我一样,爱上介款 RPC 。 首先,看到这个链接。

  贴心的我已经为你准备好了,你拷贝一下就行了,当然你要是没有 git 那就下载一个。

  然后在 console 控制台,瞎打一些东西。然后用全身的力气按一下 Enter ,你会发现,咦,发现有一些数字回显出来。喔雪特你这么这么厉害??恭喜恭喜,你学会了RMI了。

  emmm...好了,欢迎大家来到 RMI 第二层,上套路,讲代码,这上边这玩意怎么写出来的呢

  至于为什么要 继承 UnicastRemoteObject 呢。文档上的注释是这样的。用来曝露一个拥有对象引用,然后用 JRMP 协议沟通的远程对象。当然看不懂也没关系,就当没看见继续往下走。

  生成一个注册表中心,用来将服务注册到这个地方,注意这里一定要先写,不然后边的服务就没法注册上来了。

  将初始化完的服务,注册到注册中心中,这样,其他地方就可以通过注册中心获取到这个服务啦。

  完美~你可以写自己基于 RMI 的服务了。随便找个地方搞一个注册中心,注册一大堆服务上去,其他地方就可以通过这个注册中心调用了了。

  好了,欢迎大家来到 RMI 第三层,上原理,讲设计。好了,能耐心看到这里的,估计还是对这个技术有点想了解,那么我们继续讲,关于这个 RMI 技术的原理。

  还是回到这个图,我们可以看到其实这个架构还是蛮简单的。首先 RMI 是基于 socket 技术进行网络通讯的。其次本地调用的是一个叫 Client stub (存根),而这个存根跟客户端是处于同一 JVM 的。第三 Server 端其实也有一个一模一样的存根,从技术上来讲,这两个存根里边的内容是一摸一样的,只是从 Server 端下载到了 Client 端。

  RMI技术有两种使用方式,分别是继承 UnicastRemoteObject 的 由服务端直接提供服务对象类,以及继承 Activatable 的由注册中心提供激活的服务对象的方式。

  1、启动一个注册中心,这个注册中心是用 rmi 协议的,可以启动在本地的JVM也可以启动在其他地方。都是使用这个。这就是 RMI 强大的地方所在了,不仅仅 Consumer 和 Provider 可以远程,连注册中心都既可以运行在本地,也可以运行在远程。

  2、Provider 本地启动一个 SocketServer ,用来进行服务提供。找到注册中心,然后向注册中心,以某个服务名字(比如 hello) 将自己注册到注册中心中,本地保留一个 stub 存根。

  5、Consumer 拿到这个对象流后呢,用 JRMP 进行反序列化,然后创建一个代理对象,交给调用方。

  好了,这就结束了第一种了。我们看到上边的第6点,其实这些远程调用并不是远程调用,只是远程把整个对象下载到本地,然后在本地跑这些方法。所以呢,你如果觉得每次都 hold 住这个代理,就可以了,那你就错了,一旦 Provider 有任何变更,你这样干的话,是获取不到最新的服务的。

  虽然我感觉你的听得云里雾里,但是我不管,我就继续来说说第二种吧。。第二种会直接把类文件放到注册中心,然后在恰当的实际进行激活。什么叫激活呢,我的理解就是对类进行初始化,然后用序列化的方式交给调用方。

  1、启动一个注册中心,这个注册中心是用 rmi 协议的,可以启动在本地的JVM也可以启动在其他地方。都是使用这个。这就是 RMI 强大的地方所在了,不仅仅 Consumer 和 Provider 可以远程,连注册中心都既可以运行在本地,也可以运行在远程。

  2、Provider 初始化一个对象,然后类文件和自己的激活ID,激活组ID都放到注册中心。

  3、Consumer 找到注册中心,找到后寻求某个激活ID,激活组ID的服务,请求进行存根请求。

  5、Consumer 拿到来自注册中心的这个对象流后呢,用 JRMP 进行反序列化,然后创建一个代理对象,交给调用方。手机最快报码现场直播