Java的RMI(Remote Method Invocation)是远程方法调用的技术,即一个JVM的代码调用另一个JVM上的方法,使用这种技术,网络的底层实现很大程度上被隐藏了起来,客户端调用远程方法时几乎与调用本地方法差不多方便。
下面就用hello world级别的demo简单展示一下,囧……
服务端的代码——
首先要定义方法的接口,这个接口要继承java.rmi.Remote接口:
package com.lttclaw.rmi;
import java.rmi.Remote;
import java.rmi.RemoteException;
public interface MyRemote extends Remote {
public String sayHello() throws RemoteException;
}
这个接口其实是客户端和服务端共用的,可以在服务端写好然后导出jar再引入到客户端的工程里,如果这个接口里涉及到自己定义的类,则自定义类必须实现Serializable接口,并随接口一起打成jar给客户端引用。
然后我们要写一个实现类来实现我们刚才定义的接口:
package com.lttclaw.rmi;
import java.rmi.RemoteException;
public class MyRemoteImpl implements MyRemote {
protected MyRemoteImpl() throws RemoteException {
}
public String sayHello() throws RemoteException {
return "hello";
}
}
最后我们就要写服务端main方法来启动服务了
package com.lttclaw.rmi;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.rmi.server.UnicastRemoteObject;
public class Server {
public static void main(String[] args) {
try {
MyRemote myRemoteImpl=new MyRemoteImpl();
MyRemote myRemoteI=(MyRemote) UnicastRemoteObject.exportObject(myRemoteImpl, 1);
Registry registry=LocateRegistry.createRegistry(2001);
registry.rebind("hello", myRemoteI);
System.out.println("server is ready");
} catch (Exception e) {
e.printStackTrace();
}
}
}
然后运行就启动了服务了,接下来我们看客户端代码
客户端首先要把服务端的接口和接口用到的实体类引入工程,然后就可以调用了,写个最简单的调用程序,很简单——
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import javax.swing.JOptionPane;
import com.lttclaw.rmi.MyRemote;
public class RmiClient {
public static void main(String[] args) {
try {
Registry registry=LocateRegistry.getRegistry("192.168.1.60",2001);
MyRemote myRemote=(MyRemote) registry.lookup("hello");
JOptionPane.showMessageDialog(null, myRemote.sayHello());
} catch (Exception e) {
e.printStackTrace();
}
}
}
大家可以通过demo推测各个参数的含义,其实很好猜的~