JavaRMI入门实战

原创 2004年10月26日 23:07:00
(来源:http://ybwen.home.chinaren.com)

为通过网络执行其他机器上的代码,传统的方法不仅难以学习,而且易出错。解决这个问题的最佳方法是:某些对象正好位诹硪惶ɑ鳎颐强梢苑⑺鸵惶跸ⅲ⒒竦梅祷亟峁拖裎挥谧约旱谋净饕谎?span lang="EN-US">Java远程方法调用(RMI)特性使客户机上运行的程序可以调用远程服务器上的对象。远程方法调用特性使Java编程人员能够在网络环境中分布操作。

下面介绍一下必要的步骤,创建自己的RMI对象。

一、远程接口概念:

     RMI对接口有着强烈的依赖。在需要创建一个远程对象的时候,我们通过传递一个接口来隐藏基层的实施细节。所以客户得到远程对象的一个句柄正好同一些本地的根代码连接,有后者负责通过网络通信。但我们并不关心这些事情,通过自己的接口句柄发送消息即可。

   创建一个远程接口时,必须遵守下列规则:

1)  远程接口必须为public属性(不能有“包访问”;也就是说,他不能是“友好的”)。否则,一旦客户试图装载一个实现了远程接口的远程对象,就会得到一个错误。

2)  远程接口必须扩展接口java.rmi.Remote。

3)  除与应用程序本身有关的违例,远程接口中的每个方法都必须在自己的throws从句中声明java.rmi.RemoteException.

4)  作为参数或返回值传递的一个远程对象(不管是直接,还是本地对象中嵌入)必须声明为远程接口,不可声明为实施类。

下面是一个远程接口示例,

//PerfectTimeI.java<?XML:NAMESPACE PREFIX = O />

//The PerfectTime remote interface

package test;

import java.rmi.*;

public interface PerfectTimeI extends Remote {

    long getPerfectTime() throws RemoteException;

}

它表面上与其他的接口类似,只是对Remote进行了扩展,而且所有的方法都会“掷”出RemoteException.接口和方法都是Public的。

编译PerfectTimeI.java,生成PerfectTimeI.class(test是包,编译时注意路径)

G:/RMI>javac test/PerfectTimeI.java

二、远程接口的实施:

    服务器必须包含一个扩展了UnicastRemoteObject类,并实现远程接口。这个类也可以含有附加的方法,但客户只能使用远程接口中的方法。因为客户是指向接口的一个句柄,而不是它的哪个类。

   必须为远程对象定义构件器,即使只准备定义一个默认构件器,用它调用基础类构件器。必须把它明确地编写出来,因为它必须“掷”出RemoteException违例。

  下面列出远程接口PerfectTime的事实过程:他代表精确计时服务

//PerfectTime.java

//The implementation of the PerfectTime remote object

package test;

import java.net.*;

import java.rmi.*;

import java.rmi.registry.*;

import java.rmi.server.*;

public class PerfectTime extends UnicastRemoteObject implements PerfectTimeI

{

//默认构件器,也要“掷”出RemoteException违例。

    public PerfectTime() throws RemoteException {

        super();

    }

public long getPerfectTime() throws RemoteException {

    return System.currentTimeMillis();

}

public static void main(String[] args) {

/*创建和安装一个安全管理器,令其支持RMI.作为Java开发包的一部分,适用于RMI唯一一个是RMISecurityManager.*/

    System.setSecurityManager(new RMISecurityManager());

    try {

   /*创建远程对象的一个或多个实例,下面是PerfectTime对象*/

        PerfectTime pt = new PerfectTime();

   /*向RMI远程对象注册表注册至少一个远程对象。一个远程对象拥有的方法即可生成指向其他远程对象的句柄,这样,客户到注册表里访问一次,得到第一个远程对象即可.*/

        Naming.bind("PerfectTime", pt);

        System.out.println("Ready to do Time");

    } catch (Exception e) {

        e.printStackTrace();

    }

}

}

编译PerfectTime.java,生成PerfectTime.class(test是包,编译时注意路径)

G:/RMI>javac test/PerfectTime.java

三、创建根和干:

  创建RemoteObject的主干和框架。要完成这个工作可使用rmic编译器,rmic编译器生成远程对象的存根和骨架。存根(Stub)是远程对象在客户端的代理,它将RMI调用传递给服务器端的骨架(Skeleton),后者负责将该调用传递给实际的远程方法输入如下:

G:/RMI>rmic -d G:/RMI test.PerfectTime

 执行这个命令,

rmic成功运行,test目录里就会多出两个新类:

PerfectTime_Stub.class

PerfectTime_Skel.class

它们分别对应的是根(stub)和干(skeleton).

四、使用远程对象:

RMI全部的宗旨就是可能简化远程接口对象的使用。我们客户程序中要做的唯一一件额外事情是查找从服务器取回远程接口。下面就是编写的Java程序:将消息发给对象:

//DisplayPerfectTime.java

//Users remote object PerfectTime

package test;

import java.rmi.*;

import java.rmi.registry.*;

public class DisplayPerfectTime {

/*** DisplayPerfectTime 构造子注解。*/

public DisplayPerfectTime() {

    super();

}

public static void main(String[] args) {

    System.setSecurityManager(new RMISecurityManager());

    try {

        PerfectTimeI t = (PerfectTimeI) Naming.lookup("PerfectTime");

       for (int i = 0; i < 10; i++) {

           System.out.println("PerfectTime:" + t.getPerfectTime());

       }

    } catch (Exception e) {

        e.printStackTrace();

    }

}

}

编译DisplayPerfectTime.java.

G:/RMI>javac test/DisplayPerfectTime.java

五、启动注册并运行代码:

在运行PerfectTime类和DisplayPectTime类之前,用户必须首先在将要宿主PerfectTime的计算机上启动RMI注册(Registry)程序,即使将要运行PerfectTime的计算机与运行DisplayPerfectTime的是同一台机器,这一步也是必须的。注册表服务器的名字是rmiregistry.在32位Windows环境中,可使用: start rmiregistry 令其在后台运行。然后分别开两个不同的进程运行Server端和Client端:启动注册表服务器:

G:/RMI>start rmiregistry

绑定PerfectTime到注册,运行服务端程序:在Windows下,输入下列命令,在后台启动PerfectTime程序:

G:/RMI>java test.PerfectTime

Ready to do Time

运行客户端程序:如下

G:/RMI>java test.DisplayPerfectTime

PerfectTime:961722589649

PerfectTime:961722589669

PerfectTime:961722589679

PerfectTime:961722589679

PerfectTime:961722589689

PerfectTime:961722589689

PerfectTime:961722589689

PerfectTime:961722589699

PerfectTime:961722589699

PerfectTime:961722589699

JavaRMI入门实战

(来源:http://ybwen.home.chinaren.com) 为通过网络执行其他机器上的代码,传统的方法不仅难以学习,而且易出错。解决这个问题的最佳方法是:某些对象正好位于另一台机器,我们可...
  • dodorunning
  • dodorunning
  • 2006年08月10日 17:34
  • 660

Docker入门与实战讲解

简述 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不...
  • relax_hb
  • relax_hb
  • 2017年04月08日 14:53
  • 3441

Docker学习总结(1)——Docker实战之入门以及Dockerfile(一)

首先Docker是软件工业上的集装箱技术 回顾,在没有集装箱出现以前,传统运输行业中,会存在这些问题: 在运输过程中,货物损坏装卸、运输货物,效率低下运输手续繁多及运输环节多劳动强度大,及船舶周转慢...
  • u012562943
  • u012562943
  • 2016年01月05日 16:16
  • 18192

Cmake入门实战

CMake 入门实战 从实例入手,讲解 CMake 的常见用法。 Contents 什么是 CMake入门案例:单个源文件多个源文件自定义编译选项安装和测试支持 ...
  • ycl295644
  • ycl295644
  • 2017年01月07日 18:39
  • 578

Docker入门实战

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上。 Docker是一个重新定义了程序开发测试、交付和部署过程的...
  • opensure
  • opensure
  • 2015年06月14日 13:30
  • 84275

SpringBoot实战 之 入门篇

SpringBoot 简介Spring Boot 是由 Pivotal 团队提供的全新框架,其设计目的是用来简化 Spring 应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发...
  • chinrui
  • chinrui
  • 2017年04月23日 15:19
  • 1294

《Docker技术入门与实战》电子书pdf下载

《Docker技术入门与实战》 http://pan.baidu.com/s/1kTxgrzx 更多运维学习资料 http://dou.bz/35ODPo...
  • swifttrain
  • swifttrain
  • 2015年05月21日 13:19
  • 14466

Angular 4 学习笔记 从入门到实战 打造在线竞拍网站 基础知识 快速入门 个人感悟

最近搞到手了一部Angular4的视频教程,这几天正好有时间变学了一下,可以用来做一些前后端分离的网站,也可以直接去打包web app。 先上个效果图: 环境&版本信息声明 ...
  • poptxz
  • poptxz
  • 2017年07月10日 15:53
  • 5036

JavaRMI

JavaRMI入门实战为通过网络执行其他机器上的代码,传统的方法不仅难以学习,而且易出错。解决这个问题的最佳方法是:某些对象正好位于另一台机器,我们可以发送一条消息,并获得返回结果,就像位于自己的本机...
  • zhaoyabin
  • zhaoyabin
  • 2010年01月25日 16:02
  • 144

Hive从入门到实战【40讲】 ---第一天

第一天:Hive是什么,Hive的体系结构,hive和hadoop的关系 MapReduce是解决hive解决不了的问题 简单的hive能解决的问题,不需要mapReduce 做报表一般使用Hi...
  • qiezikuaichuan
  • qiezikuaichuan
  • 2015年02月03日 21:14
  • 1027
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:JavaRMI入门实战
举报原因:
原因补充:

(最多只允许输入30个字)