您的位置:首页 > 编程语言 > Java开发

java RMI远程方法调用编程模型初探

2016-06-19 15:02 525 查看
RMI是实现分布式编程的方法之一,java RMI的实现比较复杂,涉及到Socket编程,序列化等等,但是我们用起来却相当简单。下面举一个简单的例子来阐述一下RMI编程的大体框架。

大方向分为2个部分,客户端程序和服务器端程序,这二者之间的桥梁是公共的接口,接口定义了一系列服务,也就是一系列方法。如某个接口文件IHello.java内容如下:

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

public interface IHello extends Remote {
public String sayHello() throws RemoteException;
}
客户端和服务端均需要有一份该接口文件。

其次服务端需要有对该接口的实现,如HelloImpl.java,其内容如下:

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

public class HelloImpl extends UnicastRemoteObject implements IHello {

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

@Override
public String sayHello() throws RemoteException {
return "Hello, World!";
}
}
之后是需要实现服务器端程序HelloServer.java

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

public class HelloServer {

public static void main(String[] args) {
try {
IHello hello = new HelloImpl();  //创建实例对象
LocateRegistry.createRegistry(8888);  //创建注册表
Naming.bind("rmi://localhost:8888/Hello", hello); //将实例对象绑定到URL
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (RemoteException e) {
e.printStackTrace();
} catch (AlreadyBoundException e) {
e.printStackTrace();
}
}

}
上面代码中最主要的就是三板斧:第一,创建提供服务的实例对象,第二,创建注册表,第三,将实例对象绑定到URL,运行该程序,会在指定端口8888上进行监听,等待客户端的连接。

最后就是客户端的程序HelloClient.java,客户端的程序可以跟服务器端程序运行在不同的主机上,前提是必须能够通过网络访问到。

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) {
try {
IHello hello =(IHello) Naming.lookup("rmi://202.120.87.135:8888/Hello"); //在服务器端的注册表中根据URL查找对象
System.out.println(hello.sayHello());
} catch (NotBoundException e) {
e.printStackTrace();
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (RemoteException e) {
e.printStackTrace();
}
}
}
上述代码最核心的地方就是一个查找操作:Naming.lookup();之后就可以像调用本地对象一样调用远程对象的方法sayHello了。需要注意的是,在本地依然需要IHello.java这个接口代码,只不过这个接口的真正实现是在服务器端,客户端并没有该接口的实现代码。

综上所述,客户端有如下文件:

IHello.java
HelloClient.java
服务器端有如下文件:

IHello.java
HelloImpl.java
HelloServer.java
接口是用来定义服务的,客户端和服务端都需要有,而接口的实现只需要在服务端进行提供。在HelloServer.java中最核心的是如下三步:

创建实例对象:IHello hello = new HelloImpl();
创建注册表:LocateRegistry.createRegistry(8888);
将对象绑定到某个URL上:Naming.bind("rmi://localhost:8888/Hello", hello);
之后客户端和服务器端就通过这个URL联系起来。

因此在HelloClient.java中,最核心的就是如下这一步:

IHello hello =(IHello) Naming.lookup("rmi://202.120.87.135:8888/Hello");
根据URL查找远程对象,再进行强制类型转换,之后就可以调用该对象的方法了。

以上是对java RMI编程框架的粗略概述,水平有限,如有不当之处,还望指正!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java RMI