RMI的意义
定义: RMI 指的是远程方法调用 (Remote Method Invocation)。它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法。也可以说成分布式计算、可以远程调用方法。
到底有什么作用,看下面的小例子
例子:比如你有一台支持Java的手机 还有一台台式机 手机上有一个非常复杂的运算 如果用手机
来计算的话可能需要很长时间、不过如果用台式机的话几秒就结束了,这个时候就是RMI大显神通的时候,使用RMI从手机发送请求 然后交给台式机计算 然后台式机返回计算和的结果
第一步:创建一个远程接口
package com.javaer.examples.socket.rmi;
import java.rmi.Remote;
import java.rmi.RemoteException;
//创建远程接口及声明远程方法
public interface HiInterface extends Remote {
/**
* 远程接口方法必须抛出 java.rmi.RemoteException
*/
public String speak() throws RemoteException;
}
第二步:创建远程方法
package com.javaer.examples.socket.rmi;
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
//实现远程接口及远程方法(继承UnicastRemoteObject)
public class Hi extends UnicastRemoteObject implements HiInterface {
private String message;
public Hi(String msg) throws RemoteException {
super();
message = msg + " I am on server....";
}
@Override
public String speak() throws RemoteException {
return message;
}
}
第三步:实现远程Server
package com.javaer.examples.socket.rmi;
import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
//启动RMI注册服务,并注册远程对象(HiServer.java)
public class HiServer {
public static void main(String[] argv)
{
try
{
//启动RMI注册服务,指定端口为1099 (1099为默认端口)
//也可以通过命令 $java_home/bin/rmiregistry 1099启动
//这里用这种方式避免了再打开一个DOS窗口
//而且用命令rmiregistry启动注册服务还必须事先用RMIC生成一个stub类为它所用
LocateRegistry.createRegistry(1099);
//创建远程对象的一个或多个实例,下面是hello对象
//可以用不同名字注册不同的实例
HiInterface hi = new Hi("Hello, world!");
//把hi注册到RMI注册服务器上,命名为A
Naming.rebind("A", hi); //客户端通过这个A来寻找
//如果要把hi实例注册到另一台启动了RMI注册服务的机器上
//Naming.rebind("//192.168.1.105:1099/A",hi);
System.out.println("Hi Server is ready.");
}
catch (Exception e)
{
System.out.println("Hi Server failed: " + e);
}
}
}
第四步:实现本地Client
package com.javaer.examples.socket.rmi;
import java.rmi.Naming;
public class HiClient {
/**
* 查找远程对象并调用远程方法
*/
public static void main(String[] argv)
{
try
{
//HiInterface hi = (HiInterface) Naming.lookup("A");
//如果要从另一台启动了RMI注册服务的机器上查找hello实例
HiInterface hi = (HiInterface)Naming.lookup("//192.168.1.100:1099/A");
//调用远程方法
System.out.println(hi.speak());
}
catch (Exception e)
{
System.out.println("HiClient exception: " + e);
}
}
}
将四个文件编译出来一个RMI.jar
拷贝在服务器端执行
java -classpath RMI.jar com.javaer.examples.socket.rmi.HiServer
Hi Server is ready.
拷贝在客户端执行
java -classpath RMI.jar com.javaer.examples.socket.rmi.HiClient
Hello, world! I am on server....
当然,全部在本地开两个窗口也可以测试的。当时改Nutch的时候,老看到这种远程调用,当时摸不着头脑,看来当时先看看RMI,就对Nutch分布式有更深入的了解了。