如何用java编写一个rmi

网友投稿 308 2023-01-05


如何用java编写一个rmi

RMI 指的是远程方法调用 (Remote Method Invocation)。它是一种机制,能够让在某个 java虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法。可以用此方法调用的任何对象必须实现该远程接口。

调用这样一个对象时,其参数为 "marshalled" 并将其从本地虚拟机发送到远程虚拟机(该远程虚拟机的参数为 "unmarshalled")上。该方法终止时,将编组来自远程机的结果并将结果发送到调用方的虚拟机。如果方法调用导致抛出异常,则该异常将指示给调用方。

提供远端访问的时候,我们首先需要定义远端能够访问哪些东西,在Java中,定义这类接口需要实现Remote接口

public interface Business extends Remote{

public String echo(String msg) throws RemoteException;

}

定义完接口之后,这些功能是需要我们自己在Server端实现的,因此,声明一个类实现我们提供接口。

public class BusinessImpl implements Business{

@Override

public String echo(http://String msg) throws RemoteException {

if("quit".equalsIgnoreCase(msg)) {

System.out.println("Server will be shutdown");

System.exit(0);

}

System.out.println("Message from client:"+msg);

return "Server response:"+msg;

}

}

实现完这个方法之后,有一个问题是,怎么运行,既然是远端访问,肯定得有端口号,肯定得有实例,所以我们还需要注册我们的代码

public class Server {

public static final String SERVER_REGISTER_NAME = "BusineeDemo";

public static void main(String[] args) throws RemoteException {

int port = 2016;

Business business = new BusinessImpl();

UnicastRemoteObject.exportObject(business,port);

Registry registry = LocateRegistry.createRegistry(1099);

regisJwURNstqztry.rebind(SERVER_REGISTER_NAME, business);

}

}

这里有两个Java的类:UnicastRemoteObject和LocateRegistry

一个接口:Registry

Registry接口:对简单的远端对象提供一个远端接口用于提供存储和获取远端对象的引用,而这些是通过任意的String类型的变量名称获取,bind,unbind,rebind方法是用于更改注册的这些名称,lookup和list方法是用于查询当前当前已经绑定的对象。

UnicastRemoteObject类:用于导出一个远端对象

LocateRegistry类:是一个用来获得远端调用对象引用的辅助类程序,主要是在一个特定的IP上构建一个远端对象来接受来自特定端口的回调。

简单的服务端完成了,现在来看客户端:

客户端代码就更加简单,前面我们提到我们可以通过Registry的lookup方法来获取当前已经绑定的服务,所以很自然,我们首先要获得这个Registry

public class Client {

public static void main(String[] args) throws RemoteException, NotBoundException {

// Registry registry = LocateRegistry.getRegistry("localhost");

Registry registry = LocateRegistry.getRegistry("localhost", 1099);

Business business = (Business) registry.lookup(Server.SERVER_REGISTER_NAME);

System.out.println(business.echo("Hello Server"));

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java反转字符串的10种方法
下一篇:产品系统接口设计(系统接口设计原则)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~