Java的RMI初探

简介:RMI -- remote method invocation,远程方法调用;对使用者屏蔽底层通信细节,可以像调用本地方法那样调用远程方法。
 
实例:
1.服务端
1)定义提供的接口:注意必须从Remote接口派生
public interface MonitorService extends Remote{
    String getTime() throws RemoteException;
}
2)实现该接口:注意必须从UnicastRemoteObject派生,表示该对象可以被远程调用
public class MonitorServiceImpl extends UnicastRemoteObject implements MonitorService{
    protected MonitorServiceImpl() throws RemoteException {
        super();
    }
    @Override
    public String getTime() throws RemoteException {
        
        return new Date().toString();
    }
}
3)发布该接口实现:我们的service对象,就绑定在了//10.0.64.13:8900/monitor上,只要是访问这个地址,就是调用我们的对象了
        LocateRegistry.createRegistry(8900);         
        MonitorService service = new MonitorServiceImpl();        
        Naming.bind("//10.0.64.13:8900/monitor", service);
2.客户端
直接使用该接口:
MonitorService service = (MonitorService) Naming.lookup("//10.0.64.13:8900/monitor");
System.out.println(service.getTime());
 
直接运行上面的代码,我们的rmi实例就结束了。
 
讨论:
这么简单的东西,为什么感觉用的人不多呢?原因之一估计是语言的关系,使用rmi,要求通信双方都必须采用java实现;原因之二和纯正的socket通信相比,它消耗的资源还是要更多;

你可能感兴趣的:(Java,基础,java)