RMI简单实现

Posted joan-hty

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了RMI简单实现相关的知识,希望对你有一定的参考价值。

在学习EJB的时候,了解了RMI,EJB白话:把你编写的软件中那些需要执行制定的任务的类,不放到客户端软件上了,而是打包放到一个服务器上。

下面这位博主关于EJB是什么写的很详细。

https://www.cnblogs.com/strugglion/p/6027318.html

本篇重点是简单实现RMI。

RMI简单实现:

 技术分享图片

1 创建远程接口,继承Remote接口;

远程接口中声明了可以被客户端访问的远程方法,远程接口应符合以下条件:

(1)直接或间接继承java.rmi.Remote接口;

(2)接口中的所有方法声明抛出java.rmi.RemoteException异常或父异常。

 技术分享图片

2 创建远程类,实现远程接口;

远程类应符合以下条件:

(1)继承java.rmi.server.UnicastRemoteObject类并实现远程接口;

(2)构造器必须抛出java.rmi.RemoteException异常。

 技术分享图片

3 创建服务器程序

方法介绍

  •  bind(String name, Object obj): 注册对象,把对象与服务名绑定。如果该服务名已与其他对象绑定,则会抛出NameAlreadyBoundException异常。
  • rebind(String name, Object obj): 注册对象,把对象与服务名绑定。如果该服务名已与其他对象绑定,不会抛异常,而是将新的对象绑定到该服务名上。

lookup(String name) 查找对象,返回与指定名称相同的对象

技术分享图片

4 创建客户端程序

客户端根据服务名查找远程对象,然后调用远程方法。

package com.h3c;
import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;
public class HelloClient {
    public static void main(String args[])throws MalformedURLException,RemoteException,NotBoundException{
        //find  register object
        Hello hello =  (Hello) Naming.lookup("rmi://localhost:8888/Hello");
        //output the client result
        System.out.println("client:");
        System.out.println(hello.sayHello());

    }

}

 

5 先启动HelloServer,然后启动HelloClient

 技术分享图片

技术分享图片

 

以上是关于RMI简单实现的主要内容,如果未能解决你的问题,请参考以下文章

普通方法实现——远程方法调用RMI代码演示

rmi简单用例,简单有效

代码片段 - Golang 实现简单的 Web 服务器

Spring框架实现——远程方法调用RMI代码演示

rmi 回调陷阱?

RMI如何实现轮询机制?