




已阅读5页,还剩45页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第七次课RMI,RMI,一、RMI概述,二、RMI体系结构,七、实现回调,三、RMI工作机制,四、一个简单的RMI例子,五、第二个例题,六、实现工厂,八、思考和作业,一、什么是RMI,一、RMI概述,RMI是指远程方法调用,将客户和服务器间的接口抽象为一个本地的过程调用。RMI是可用于开发分布式程序的JDK核心包。在所编写的分布式程序中,其远程对象的方法能够被运行在不同主机上的其他Java虚拟机的方法调用。当所有参数被传递给远程目标并被解释,然后将结果返回给调用者。这个过程给程序员一个错觉:以为是从本地类文件中调用一个本地方法。,1、什么是RMI,一、RMI概述,RMI是指远程方法调用,将客户和服务器间的接口抽象为一个本地的过程调用。,对象,应用程序,本地调用,机器A,对象,对象,机器B,对象,网络,远程调用,1、什么是RMI,一、RMI概述,RMI的特征:透明调用分布的垃圾回收对流的方便访问,对象,应用程序,本地调用,机器A,对象,对象,机器B,对象,网络,远程调用,1、RMI系统组成,二、RMI体系结构,RMI系统有三层组成桩/架构(stub/skeleton)远程引用层传输层,桩,构架,远程引用层,传输层,服务器,客户,2、RMI系统组成:桩/架构层,二、RMI体系结构,桩/架构层是应用程序与系统其他部分的接口当完成服务器应用程序开发后,就是用RMI的misc编译器产生桩/架构层,它根据服务器程序的字节代码,产生代理类。桩是客户端的代理,桩允许客户与系统的其它层通信。架构是服务器端的入口,2、RMI系统组成:桩/架构层,二、RMI体系结构,桩/架构层是应用程序与系统其他部分的接口远程对象客户端桩的任务初始化远程调用序列化发送参数指示远程引用层将要进行调用反序列化返回值提示远程传输层调用完成,2、RMI系统组成:桩/架构层,二、RMI体系结构,桩/架构层是应用程序与系统其他部分的接口服务器端架构的任务反序列化客户端输入的参数调用实际的远程对象实现将返回值序列化为流以传输给客户,3、RMI系统组成:远程调用层,二、RMI体系结构,远程调用层是桩/架构层和传输层的中间层远程调用层负责为独立于客户桩和服务器架构的多种形式的远程调用和调用协议提供支持。单点传送协议可能提供点对点的调用多点传输协议提供对复制的成组对象的调用。,二、RMI体系结构,4、RMI系统组成:传输层,传输层负责建立到远程地址空间的连接管理连接监听外来调用维护驻留于同一个地址空间的远程对象表为外来的调用建立连接,以及根据远程调用的目的定为调度程序,并传递连接给该调度程序。同一个地址空间可以支持TCP和UDP两种协议。,1、RMI工作过程,三、RMI工作机制,通常,调用通过桩/架构层传递,桩/架构层作为应用程序与RMI系统的其他部分的一个接口来提供服务:通过序列化流,将数据传输到远程引用层。一旦数据通过桩/架构层传递,它将通过远程引用层,远程引用层实现了调用的语义,把数据传输到传输层。最后,数据到达传输层。,1、创建RMI应用程序的步骤,四、一个简单的RMI例子,1)定义一个远程接口2)实现远程接口和服务器3)使用远程接口开发一个客户程序4)产生桩和架构5)启动RMI注册表6)运行服务器程序和客户程序,2、应用举例:定义一个远程接口,四、一个简单的RMI例子,设计一个接口时需要考虑所要支持的方法和每一个方法所需的参数。客户通过远程接口了解服务器提供的方法以及如何调用这些方法。RMI使用异常来报告错误信息:如由于服务器关机,超载等原因无法和服务器建立连接。远程对象需要声明为public的,并扩展接口java.rmi.Remote接口中的每一个方法都必须声明为java.rmi,throws一句中必须抛出RemoteException异常。,2、应用举例-算术服务器:定义一个远程接口,四、一个简单的RMI例子,publicinterfaceArithextendsjava.rmi.Remoteintadd(inta,intb)throwsjava.rmi.RemoteException;,远程对象需要声明为public的扩展接口java.rmi.Remote接口中的每一个方法都必须声明为java.rmi,throws一句中必须抛出RemoteException异常。,2、应用举例-算术服务器:实现远程接口,四、一个简单的RMI例子,指定要执行的远程接口定义远程对象成员器实现能被远程调用的方法创建一个安全管理器的实例,并安装它创建远程对象的一个或多个实例注册一个远程对象到RMI注册器,publicclassArithImplextendsUnicastRemoteObjectimplementsArithprivateStringobjectName;publicArithImpl(Strings)throwsRemoteExceptionpublicintadd(inta,intb)publicstaticvoidmain(Stringargs),2、应用举例-算术服务器:实现远程接口,四、一个简单的RMI例子,publicclassArithImplextendsUnicastRemoteObjectimplementsArithprivateStringobjectName;publicArithImpl(Strings)throwsRemoteExceptionsuper();objectName=s;publicintadd(inta,intb)intc=newint10;for(inti=0;i10;i+)ci=ai+bi;returnc;,ArithImpl用于创建一个单一的、非复制远程对象,使用RMI默认的基于Socket的传输,实现接口方法,传递两个整型数组给add()方法,返回一个整型数组。,2、应用举例-算术服务器:实现远程接口,四、一个简单的RMI例子,publicclassArithImplextendsUnicastRemoteObjectimplementsArithpublicstaticvoidmain(Stringargs)RMISecurityManagersm=newRMISecurityManager();System.setSecurityManager(sm);tryArithImplobj=newArithImpl(ArithServer);Naming.rebind(rmi:/:1099/ArithServer,obj);System.out.println(ArithServerboundinregistry);catch(Exceptione)System.out.println(ArithImplerror:+e.getMessage();e.printStackTrace();,创建并安装一个安全管理器,保护主机不受客户恶意代码的损坏。,2、应用举例-算术服务器:实现远程接口,四、一个简单的RMI例子,ArithImplobj=newArithImpl(ArithServer);,创建远程对象实例,服务器准备好监听客户的请求。,Naming.rebind(rmi:/:1099/ArithServer,obj);,将远程对象注册到RMI注册表中,以便客户获得对远程对象的引用,能够调用远程对象中的方法。RMI系统提供了一个基于URL注册的解决方法,以/host/objectName的形式绑定对象。1099是RMI注册表运行的默认的端口号。,2、应用举例-算术服务器:使用远程接口开发客户程序:ArithApp.java,四、一个简单的RMI例子,客户必须首先从服务程序的注册表中获得对ArithServer的引用,然后远程调用方法add,将数组a和b相加,将返回值保存在新数组result中。,3、调试运行过程,四、一个简单的RMI例子,1)编译接口和类文件,2)产生桩和架构编写完所有的代码后,就需要产生桩和架构。桩和架构在运行时确定,并根据需要动态加载。,客户,网络,桩,客户,桩,3、调试运行过程,四、一个简单的RMI例子,3)启动RMI注册表RMI注册表是一个名字服务,允许客户程序对远程对象进行引用。RMI注册表可以看做是RMI远程对象引用的管理器。,运行注册表,并使之监听默认的1099端口,3、调试运行过程,四、一个简单的RMI例子,4)运行服务程序和客户程序,4、调试过程中可能出现的问题及解决方案,四、一个简单的RMI例子,1)错误一:,原因:无法解析和连接到的1099端口上,原因是设置了安全管理器System.setSecurityManager(newRMISecurityManager();,可是又没有设置访问的策略,4、调试过程中可能出现的问题及解决方案,四、一个简单的RMI例子,1)错误一:,解决办法:1)把代码System.setSecurityManager(newRMISecurityManager();去掉,不设置安全管理器2)修改JRE的安全策略文件,在Eclipse中用JDK是c:Javajdk1.5.0_06,相应的安全策略文件就是c:javajdk1.5.0_06jrelibsecurityjava.policy,五、第二个例题,1.例题2:城市信息服务器,城市信息服务器提供某一城市人口和温度的查询,客户通过输入城市名可以获取该城市的人口数和温度等信息。简单代码实现定义远程接口:City.java实现远程接口:CityImpl.java开发客户端程序:CityApp.java运行该程序:编译上述三个类文件产生桩和架构启动RMI注册运行服务器和客户程序,1.例题2:城市信息服务器,运行界面,五、第二个例题,1.例题2:城市信息服务器,类文件结构及其相互关系,publicinterfaceCityextendsRemote,publicclassCityImplextendsUnicastRemoteObjectimplementsCity,publicclassCityApp,客户,远程对象,RMI注册表,2.查询,1.注册,3.调用方法,五、第二个例题,1.例题2:城市信息服务器,类文件结构及其相互关系,publicclassCityImplextendsUnicastRemoteObjectimplementsCitypublicintgetPopulation(StringcityName)publicintgetTemperature(StringcityName)publicstaticvoidmain(Stringargs)CityImplobj=newCityImpl(CityServer);Naming.rebind(rmi:/:1099/CityServer,obj);System.out.println(cityServerboundinregistry!);,publicclassCityAppCityobj=(City)Naming.lookup(rmi:/:1099/CityServer);pop=obj.getPopulation(Toronto);System.out.println(ThepopulationofTorontois:+pop);,远程对象,注册,查询远程对象,调用其方法,五、第二个例题,2.例题2:城市信息服务器分析,由于CityImpl.java继承了UnicastRemotObject,所以RMI客户无法启动RMI服务器程序及其创建它的实例。,publicclassCityImplextendsUnicastRemoteObjectimplementsCity,如果用一个城市信息服务器来处理与所有城市相关的信息,会导致服务器过载,解决这一问题,可以为每个城市创建一个不同的CityImpl服务器,要求该服务器只处理与该城市有关的信息请求。通过工厂Factory,创建动态服务器:客户程序中能够启动服务器程序及实例化该对象。,五、第二个例题,六、实现工厂,1.工厂概述及工厂接口定义,使用工厂,可以创建远程对象的多个实例,并使它们能够相互调用。工厂只有一个负责创建对象的方法,该方法所创建的对象以后将被客户程序作为一般的服务器程序来使用。定义工厂接口:CityFactory.javapublicinterfaceCityFactoryextendsRemoteCity2ImplgetCityServer(StringcityName)throwsRemoteException;通过参数cityName创建动态服务器。,六、实现工厂,2.定义远程接口City2.java,publicinterfaceCity2extendsRemoteintgetPopulation()throwsRemoteException;intgetTemperature()throwsRemoteException;,用工厂实现动态服务器时,在调用接口中的getPopulation()方法之前,由于已经生成某一cityName的城市服务器,故这里调用这些方法时不需要再进行参数传递。,六、实现工厂,3.实现远程接口City2Impl.java,main()去哪里了?,六、实现工厂,3.实现远程接口City2Impl.java,功能:根据工厂给出的城市名cityName,使用该类创建一个信息服务器实例,构造方法:被工厂方法调用,以为指定的城市名cityName初始化一个服务器程序,六、实现工厂,4.实现CityFactory接口CityFactoryImpl.java,根据参数cityName返回不同的服务器实例,安全管理器向RMI注册表注册产生桩和架构,六、实现工厂,5.调用接口City2App.java,生成服务器实例,调用服务器实例方法,5.调用接口City2App.java,六、实现工厂,6.类文件结构及相互关系,CityFactoryImplgetCityServer(cityName)main():注册,桩,架构,City2AppNaming.lookup名字空间查询newCityFactoryImpl().getCityServer(Ottawa)ottawaPopulation=ottawa.getPopulation();,City2ImplgetPopulation()getTemperature(),City2,getPopulation()getTemperature(),CityFactory,getCityServer(cityName),RMI注册表,Ottawa实例getPopulation()getTemperature(),六、实现工厂,7.运行工厂,1)编译文件,2)生成桩,架构,注册,3)运行客户端程序,七、实现回调,1.回调概述,回调是对程序员所定义方法的调用,它被应用程序执行,以对用户的操作作出响应。,okBtn.addActionListener(this);,publicvoidactionPerformed(ActionEvente)if(e.getSource()=okBtn)eventHandle();,在Java中,一般通过使用接口以及实现该接口的类,来实现回调。,classGuessNumberimplementsActionListener,七、实现回调,2.RMI中实现回调,回调可用于许多场合中,如一个城市的温度信息到达城市信息服务器后,该服务器的客户端想要更新它,所以客户端需要一个方法,以便在服务器端有新的信息出现时,服务器程序可以调用它:定义一个客户回调接口。,调用,回调,七、实现回调,3.定义客户回调接口Callback.java,publicinterfaceCallbackvoidtempChanged(StringcityName,inttemp);,参数为城市名和城市温度,当该方法被服务器回调时,客户端将根据到达的服务器的新信息,显示该城市的新温度。为了让服务器将更新信息发送给客户端,必须发送一个Callback类型的对象到服务器,以便服务器进行回调。所以将City接口修改为CallCity接口,七、实现回调,3.修改City接口:CallCity.java,publicinterfaceCallCityextendsRemoteintgetPopulation(StringcityName)throwsRemoteException;intgetTemperature(StringcityName)throwsRemoteException;voidregister(Callbackcb)throwsRemoteException;,七、实现回调,3.实现Callback接口:CallCityApp.java,publicclassCallCityAppimplementsCallback,Serializablepublicstaticvoidmain(Stringargs)intpop=0;tryCallCityobj=(CallCity)Naming.lookup(rmi:/:1099/CallCityImpl);pop=obj.getPopulation(Toronto);catch(Exceptione)e.printStackTrace();System.out.println(ThepopulationofTorontois:+pop);publicvoidtempChanged(StringcityName,inttemp)System.out.println(DynamicUpdate:);System.out.println(CityName:+cityName);System.out.println(Temp:+temp);,客户程序通过显示接收到的新信息,提供Callback接口的一个简单实现。,七、实现回调,3.城市信息服务器:CallCityImpl.java,需要对城市信息服务器进行修改,以在City接口中实现新的方法register,服务器端维护一个当新信息到达服务器时需要回调的客户列表。publicclassCallCityImplextendsUnicastRemoteObjectimplementsCallCityVectorlist=newVector();privateStringname;publicCallCityImpl(Stringname)throwsRemoteExceptionpublicintgetPopulation(StringcityName)throwsRemoteExceptionpublicvoidregister(Callbackcb)publicstaticvoidmain(Stringargs),七、实现回调,3.城市信息服务器:CallCityImpl.java,publicCallCityImpl(Stringname)throwsRemoteExceptionsuper();=name;publicintgetPopulation(StringcityName)throwsRemoteExceptionif(cityName.equals(Toronto)return10;elseif(cityName.equals(Ottawa)retu
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 广告投放策略优化设计手册
- 商业照明设计服务协议
- 演示材料协议
- 2026届广东省汕头市达濠华桥中学高三化学第一学期期中经典模拟试题含解析
- 农民贷款申请书
- 三农文化活动组织策划指南
- 浙江省镇海中学2026届化学高一第一学期期末达标检测试题含解析
- 办公室欠款合同样本
- 农业资源高效利用与开发协议
- 农村土地整治与农业合作社合作协议
- 2025年 江苏苏州昆山国创投资集团有限公司第一期招聘考试试卷附答案
- 医院培训课件:《头晕临床思维》
- 产品合格证出厂合格证A4打印模板
- 写作指南|扎根理论的三级编码及操作中的常见问题
- 数字经济学导论-全套课件
- 初中英语语法句型转换综合训练100题(含参考答案)
- 选题策划导论PPT完整全套教学课件
- 奥氏体不锈钢对接接头超声检测方法和质量分级
- 新航标职业英语语音技能教程unit
- 普通高中语文课程标准测试题及答案
- 正确认识胰岛素
评论
0/150
提交评论