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

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中最核心的是如下三步:

  1. 创建实例对象:IHello hello = new HelloImpl();
  2. 创建注册表:LocateRegistry.createRegistry(8888);
  3. 将对象绑定到某个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,java,RMI)