什么是RMI:
RMI是远程方法调用(Remote Method Invocation)。能够让在某个Java虚拟机上的对象像调用本地对象一样调用另一个Java 虚拟机中的对象上的方法。将网络通讯和并发控制对程序开发人员透明化,那么将极度简化此类应用的开发成本,RMI就是这样一个范例。
优点:
RMI是Java的一组拥护开发分布式应用程序的API。RMI使用Java语言接口定义了远程对象,它集合了Java序列化和Java远程方法协议(Java Remote Method Protocol)。简单地说,这样使原先的程序在同一操作系统的方法调用,变成了不同操作系统之间程序的方法调用,由于J2EE是分布式程序平台,它以RMI机制实现程序组件在不同操作系统之间的通信。 RMI大大增强了Java开发分布式应用的能力,是开发百分之百纯Java的网络分布式应用系统的核心解决方案之一。其实它可以被看作是RPC的Java版本。但是传统RPC并不能很好地应用于分布式对象系统。而Java RMI 则支持存储于不同地址空间的程序级对象之间彼此进行通信,实现远程对象之间的无缝远程调用,用RMI开发的应用系统可以部署在任何支持JRE的平台上。
RMI使用的一般流程:
1,客户对象调用客户端辅助对象上的方法;
2,客户端辅助对象打包调用信息(变量,方法名),通过网络发送给服务端辅助对象;
3,服务端辅助对象将客户端辅助对象发送来的信息解包,找出真正被调用的方法以及该方法所在对象;
4,调用真正服务对象上的真正方法,并将结果返回给服务端辅助对象;
5,服务端辅助对象将结果打包,发送给客户端辅助对象;
6,客户端辅助对象将返回值解包,返回给客户对象;
7,客户对象获得返回值。
对于客户对象来说,步骤2-6是完全透明的,也就意味着,开发人员无需关注任何的网络数据传输处理。
案例:
服务端及客户端结构图
服务端代码:
1. 接口源文件:
import java.rmi.Remote; import java.rmi.RemoteException; //必须继承Remote类 public interface IBiz extends Remote { //方法必须抛出 RemoteException 异常 public String sayHello(String name) throws RemoteException; } |
2. 接口实现类。
import java.rmi.RemoteException; import com.icss.service.IBiz; public BizImpl() throws RemoteException { |
3. 服务端启动类:
public class Main { public static void main(String[] args) { try { //接口对象创建 IBiz biz = new BizImpl(); //注册端口 LocateRegistry.createRegistry(10001); //发布服务:IP+端口+服务名 Naming.bind("rmi://172.17.4.78:10001/h", biz); } catch (Exception e) { System.out.println(e.getMessage()); } } } |
客户端:
1. 原样拷贝接口源文件(包括包路径)到客户端,看项目结构图。
2. 客户端启动类:
public class Main { public static void main(String[] args) { try { //根据IP+端口+服务名称从服务端获取接口对象 IBiz biz = (IBiz) java.rmi.Naming.lookup("rmi://172.17.4.78:10001/h"); //调用接口代理对象的方法。 System.out.println(biz.sayHello("张三")); } catch (Exception e) { System.out.println(e.getMessage()); } } } |