Java RMI 简单实现
提供远端访问的时候,我们首先需要定义远端能够访问哪些东西,在Java中,定义这类接口需要实现Remote接口
1 public interface Business extends Remote{ 2 3 public String echo(String msg) throws RemoteException; 4 5 }
定义完接口之后,这些功能是需要我们自己在Server端实现的,因此,声明一个类实现我们提供接口。
1 public class BusinessImpl implements Business{ 2 3 @Override 4 public String echo(String msg) throws RemoteException { 5 if("quit".equalsIgnoreCase(msg)) { 6 System.out.println("Server will be shutdown"); 7 System.exit(0); 8 } 9 System.out.println("Message from client:"+msg); 10 return "Server response:"+msg; 11 } 12 } 13
实现完这个方法之后,有一个问题是,怎么运行,既然是远端访问,肯定得有端口号,肯定得有实例,所以我们还需要注册我们的代码
1 public class Server { 2 3 public static final String SERVER_REGISTER_NAME = "BusineeDemo"; 4 5 public static void main(String[] args) throws RemoteException { 6 int port = 2016; 7 Business business = new BusinessImpl(); 8 UnicastRemoteObject.exportObject(business,port); 9 Registry registry = LocateRegistry.createRegistry(1099); 10 registry.rebind(SERVER_REGISTER_NAME, business); 11 } 12 }
这里有两个Java的类:UnicastRemoteObject和LocateRegistry
一个接口:Registry
Registry接口:对简单的远端对象提供一个远端接口用于提供存储和获取远端对象的引用,而这些是通过任意的String类型的变量名称获取,bind,unbind,rebind方法是用于更改注册的这些名称,lookup和list方法是用于查询当前当前已经绑定的对象。
UnicastRemoteObject类:用于导出一个远端对象
LocateRegistry类:是一个用来获得远端调用对象引用的辅助类程序,主要是在一个特定的IP上构建一个远端对象来接受来自特定端口的回调。
简单的服务端完成了,现在来看客户端:
客户端代码就更加简单,前面我们提到我们可以通过Registry的lookup方法来获取当前已经绑定的服务,所以很自然,我们首先要获得这个Registry
1 public class Client { 2 3 public static void main(String[] args) throws RemoteException, NotBoundException { 4 // Registry registry = LocateRegistry.getRegistry("localhost"); 5 Registry registry = LocateRegistry.getRegistry("localhost", 1099); 6 Business business = (Business) registry.lookup(Server.SERVER_REGISTER_NAME); 7 System.out.println(business.echo("Hello Server")); 8 } 9 }