java RMI远程方法调用编程模型初探
2016-06-19 15:02
525 查看
RMI是实现分布式编程的方法之一,java RMI的实现比较复杂,涉及到Socket编程,序列化等等,但是我们用起来却相当简单。下面举一个简单的例子来阐述一下RMI编程的大体框架。
大方向分为2个部分,客户端程序和服务器端程序,这二者之间的桥梁是公共的接口,接口定义了一系列服务,也就是一系列方法。如某个接口文件IHello.java内容如下:
其次服务端需要有对该接口的实现,如HelloImpl.java,其内容如下:
最后就是客户端的程序HelloClient.java,客户端的程序可以跟服务器端程序运行在不同的主机上,前提是必须能够通过网络访问到。
综上所述,客户端有如下文件:
IHello.java
HelloClient.java
服务器端有如下文件:
IHello.java
HelloImpl.java
HelloServer.java
接口是用来定义服务的,客户端和服务端都需要有,而接口的实现只需要在服务端进行提供。在HelloServer.java中最核心的是如下三步:
创建实例对象:IHello hello = new HelloImpl();
创建注册表:LocateRegistry.createRegistry(8888);
将对象绑定到某个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编程框架的粗略概述,水平有限,如有不当之处,还望指正!
大方向分为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中最核心的是如下三步:
创建实例对象:IHello hello = new HelloImpl();
创建注册表:LocateRegistry.createRegistry(8888);
将对象绑定到某个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对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- c++11 + SDL2 + ffmpeg +OpenAL + java = Android播放器
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序
- 二叉查找树