Java中的RPC分布式范例:RMI

什么是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 java.rmi.server.UnicastRemoteObject;

import com.icss.service.IBiz;
//必须继承 UnicastRemoteObject类
public class BizImpl extends UnicastRemoteObject implements IBiz {

    public BizImpl() throws RemoteException {
        super();
    }
    //重写接口方法
    @Override
    public String sayHello(String name) throws RemoteException {
        return "Hello:"+name;
    }
}

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());
        }
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值