网络编程技术第七次.ppt
《网络编程技术第七次.ppt》由会员分享,可在线阅读,更多相关《网络编程技术第七次.ppt(50页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第七次课 RMI计算机科学与技术学院计算机科学与技术学院 网络工程教研室网络工程教研室 袁卫华袁卫华计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室RMI一、一、RMI概述概述二、二、RMI体系结构体系结构七、实现回调七、实现回调三、三、RMI工作机制工作机制四、一个简单的四、一个简单的RMI例子例子五、第二个例题五、第二个例题六、实现工厂六、实现工厂八、思考和作业八、思考和作业 计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室一、什么是一、什么是RMI一、RMI概述RMI是指远程方法调用,将客户和服务器间的接口抽象为是指远程方法调用,将客户和服务器间的
2、接口抽象为一个本地的过程调用。一个本地的过程调用。uRMI是可用于开发分布式程序的是可用于开发分布式程序的JDK核心包。核心包。在所在所编写的分布式程序中,其写的分布式程序中,其远程程对象的方法能象的方法能够被运被运行在不同主机上的其他行在不同主机上的其他Java虚虚拟机的方法机的方法调用。用。当所有参数被当所有参数被传递给远程目程目标并被解并被解释,然后将,然后将结果返果返回回给调用者。用者。这个个过程程给程序程序员一个一个错觉:以:以为是从本地是从本地类文件中文件中调用用一个本地方法。一个本地方法。计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室1、什么是、什么是RMI
3、一、RMI概述RMI是指远程方法调用,将客户和服务器间的接口抽象为是指远程方法调用,将客户和服务器间的接口抽象为一个本地的过程调用。一个本地的过程调用。对象对象应用程序应用程序本地本地调用用机器机器A对象对象对象对象机器机器B对象对象网络网络远程程调用用计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室1、什么是、什么是RMI一、RMI概述RMI的特征:的特征:透明调用透明调用分布的垃圾回收分布的垃圾回收对流的方便访问对流的方便访问对象对象应用程序应用程序本地本地调用用机器机器A对象对象对象对象机器机器B对象对象网络网络远程程调用用计算机科学与技术学院网络工程教研室计算机科学
4、与技术学院网络工程教研室1、RMI系统组成系统组成二、RMI体系结构RMI系统有三层组成系统有三层组成桩桩/架构(架构(stub/skeleton)远程引用层远程引用层传输层传输层桩桩构架构架远程引用层远程引用层传输层传输层服务器服务器客户客户计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室2、RMI系统组成:桩系统组成:桩/架构层架构层二、RMI体系结构桩桩/架构层是应用程序与系统其他部分的接口架构层是应用程序与系统其他部分的接口当完成服务器应用程序开发后,就是用当完成服务器应用程序开发后,就是用RMI的的misc编译器产编译器产生桩生桩/架构层,它根据服务器程序的字节代
5、码,产生代理类。架构层,它根据服务器程序的字节代码,产生代理类。桩是客是客户端的代理,端的代理,桩允允许客客户与系与系统的其它的其它层通信。通信。架构是服架构是服务器端的入口器端的入口计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室2、RMI系统组成:桩系统组成:桩/架构层架构层二、RMI体系结构桩桩/架构层是应用程序与系统其他部分的接口架构层是应用程序与系统其他部分的接口远程对象远程对象客户端桩客户端桩的任务的任务初始化初始化远程程调用用序列化序列化发送参数送参数指示指示远程引用程引用层将要将要进行行调用用反序列化返回反序列化返回值提示提示远程程传输层调用完成用完成计算机
6、科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室2、RMI系统组成:桩系统组成:桩/架构层架构层二、RMI体系结构桩桩/架构层是应用程序与系统其他部分的接口架构层是应用程序与系统其他部分的接口服务器端服务器端架构架构的任务的任务反序列化客反序列化客户端端输入的参数入的参数调用用实际的的远程程对象象实现将返回将返回值序列化序列化为流以流以传输给客客户计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室3、RMI系统组成:远程调用层系统组成:远程调用层二、RMI体系结构远程调用层远程调用层是桩是桩/架构层和传输层的中间层架构层和传输层的中间层远程调用层负责为独立于客户
7、桩和服务器架构的多种形远程调用层负责为独立于客户桩和服务器架构的多种形式的远程调用和调用协议提供支持。式的远程调用和调用协议提供支持。单点点传送送协议可能提供点可能提供点对点的点的调用用多点多点传输协议提供提供对复制的成复制的成组对象的象的调用。用。计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室二、RMI体系结构4、RMI系统组成:传输层系统组成:传输层传输层负责建立到远程地址空间的连接传输层负责建立到远程地址空间的连接管理连接管理连接监听外来调用监听外来调用维护驻留于同一个地址空间的远程对象表维护驻留于同一个地址空间的远程对象表为外来的调用建立连接,以及根据远程调用的目
8、的定为调为外来的调用建立连接,以及根据远程调用的目的定为调度程序,并传递连接给该调度程序。度程序,并传递连接给该调度程序。同一个地址空同一个地址空间可以支持可以支持TCP和和UDP两种两种协议。计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室1、RMI工作过程工作过程三、RMI工作机制通常,调用通过桩通常,调用通过桩/架构层传递,架构层传递,桩桩/架构层架构层作为应用程序作为应用程序与与RMI系统的其他部分的一个接口来提供服务:通过序列系统的其他部分的一个接口来提供服务:通过序列化流,将数据传输到化流,将数据传输到远程引用层远程引用层。一旦数据通过一旦数据通过桩桩/架构层传
9、递架构层传递,它将通过,它将通过远程引用层远程引用层,远,远程引用层实现了调用的语义,把数据传输到程引用层实现了调用的语义,把数据传输到传输层传输层。最后,数据到达最后,数据到达传输层传输层。计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室1、创建、创建RMI应用程序的步骤应用程序的步骤四、一个简单的RMI例子1)定义一个远程接口)定义一个远程接口2)实现远程接口和服务器)实现远程接口和服务器3)使用远程接口开发一个客户程序)使用远程接口开发一个客户程序4)产生桩和架构)产生桩和架构5)启动)启动RMI注册表注册表6)运行服务器程序和客户程序)运行服务器程序和客户程序计算机
10、科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室2、应用举例:定义一个远程接口、应用举例:定义一个远程接口四、一个简单的RMI例子设计一个接口时需要考虑所要支持的方法和每一个方法所设计一个接口时需要考虑所要支持的方法和每一个方法所需的参数。需的参数。客客户通通过远程接口了解服程接口了解服务器提供的方法以及如何器提供的方法以及如何调用用这些方法。些方法。RMI使用异常来使用异常来报告告错误信息:如由于服信息:如由于服务器关机,超器关机,超载等原因无法和服等原因无法和服务器建立器建立连接。接。远程对象需要声明为远程对象需要声明为public的,并扩展接口的,并扩展接口接口中的每一个方
11、法都必须声明为接口中的每一个方法都必须声明为java.rmi,throws一句一句中必须抛出中必须抛出RemoteException异常。异常。计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室2、应用举例、应用举例-算术服务器:算术服务器:定义一个远程接口定义一个远程接口四、一个简单的RMI例子public interface Arith extends int add(int a,int b)throws java.rmi.RemoteException;远程对象需要声明为远程对象需要声明为public的的扩展接口扩展接口接口中的每一个方法都必须声明为接口中的每一个方法都
12、必须声明为java.rmi,throws一句一句中必须抛出中必须抛出RemoteException异常。异常。计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室2、应用举例、应用举例-算术服务器:算术服务器:实现远程接口实现远程接口四、一个简单的RMI例子指定要执行的远程接口指定要执行的远程接口定义远程对象成员器定义远程对象成员器实现能被远程调用的方法实现能被远程调用的方法创建一个安全管理器的实例,并安装它创建一个安全管理器的实例,并安装它创建远程对象的一个或多个实例创建远程对象的一个或多个实例注册一个远程对象到注册一个远程对象到RMI注册器注册器public class A
13、rithImpl extends UnicastRemoteObject implements Arith private String objectName;public ArithImpl(String s)throws RemoteException public int add(int a,int b)public static void main(String args)计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室2、应用举例、应用举例-算术服务器:算术服务器:实现远程接口实现远程接口四、一个简单的RMI例子public class ArithImpl ext
14、ends UnicastRemoteObject implements Arith private String objectName;public ArithImpl(String s)throws RemoteException super();objectName=s;public int add(int a,int b)int c=new int10;for(int i=0;i 10;i+)ci=ai+bi;return c;ArithImpl用于创建一个单一用于创建一个单一的、非复制远程对象,使用的、非复制远程对象,使用RMI默认的基于默认的基于Socket的传输的传输实现接口方法,
15、传递两个整型实现接口方法,传递两个整型数组给数组给add()方法,返回一个整方法,返回一个整型数组。型数组。计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室2、应用举例、应用举例-算术服务器:算术服务器:实现远程接口实现远程接口四、一个简单的RMI例子public class ArithImpl extends UnicastRemoteObject implements Arith public static void main(String args)RMISecurityManager sm=new RMISecurityManager();System.setSec
16、urityManager(sm);try ArithImpl obj=new ArithImpl(ArithServer);Naming.rebind(rmi:/127.0.0.1:1099/ArithServer,obj);System.out.println(ArithServer bound in registry);catch(Exception e)System.out.println(ArithImpl error:+e.getMessage();e.printStackTrace();创建并安装一个安全管理器,保护主机不受客创建并安装一个安全管理器,保护主机不受客户恶意代码的损坏
17、。户恶意代码的损坏。计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室2、应用举例、应用举例-算术服务器:算术服务器:实现远程接口实现远程接口四、一个简单的RMI例子ArithImpl obj=new ArithImpl(ArithServer);创建远程对象实例,服务器准备好监听客户的请求。创建远程对象实例,服务器准备好监听客户的请求。Naming.rebind(rmi:/127.0.0.1:1099/ArithServer,obj);将远程对象注册到将远程对象注册到RMI注册表中,以便客户获得对远程注册表中,以便客户获得对远程对象的引用,能够调用远程对象中的方法。对象的引
18、用,能够调用远程对象中的方法。RMI系统提供了一个基于系统提供了一个基于URL注册的解决方法,以注册的解决方法,以/host/objectName的形式绑定对象。的形式绑定对象。1099是是RMI注册表运行的默注册表运行的默认的端口号。的端口号。计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室2、应用举例、应用举例-算术服务器:算术服务器:使用远程接口开发客户程序使用远程接口开发客户程序:ArithApp.java四、一个简单的RMI例子客户必须首先从服务程序的客户必须首先从服务程序的注册表中获得对注册表中获得对ArithServer的的引用,然后远程调用方法引用,然后远程
19、调用方法add,将数组,将数组a和和b相加,将返回值相加,将返回值保存在新数组保存在新数组result中。中。计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室3、调试运行过程、调试运行过程四、一个简单的RMI例子1)编译接口和类文件)编译接口和类文件2)产生桩和架构)产生桩和架构编写完所有的代码后,就需要产生桩和架构。编写完所有的代码后,就需要产生桩和架构。桩和架构在运行时确定,并根据需要动态加载。桩和架构在运行时确定,并根据需要动态加载。客户客户网络网络桩桩客户客户桩桩计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室3、调试运行过程、调试运行过程四、一
20、个简单的RMI例子3)启动)启动RMI注册表注册表RMI注册表是一个名字服务,允许客户程序对远程对象进行注册表是一个名字服务,允许客户程序对远程对象进行引用。引用。RMI注册表可以看做是注册表可以看做是RMI远程对象引用的管理器。远程对象引用的管理器。客户客户远程对象远程对象RMI注册表注册表2.查询查询1.注册注册3.调用方法调用方法运行注册表,并使之监运行注册表,并使之监听默认的听默认的1099端口端口计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室3、调试运行过程、调试运行过程四、一个简单的RMI例子4)运行服务程序和客户程序)运行服务程序和客户程序计算机科学与技术学
21、院网络工程教研室计算机科学与技术学院网络工程教研室4、调试过程中可能出现的问题及解决方案、调试过程中可能出现的问题及解决方案四、一个简单的RMI例子1)错误一:)错误一:原因:无法解析和连接到原因:无法解析和连接到的的1099端口上,原因是设置了安端口上,原因是设置了安全管理器全管理器System.setSecurityManager(new RMISecurityManager();,可是又没有设置访问的策略,可是又没有设置访问的策略计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室4、调试过程中可能出现的问题及解决方案、调试过程中可能出现的问题及解决方案四、一个简单的RM
22、I例子1)错误一:)错误一:解决办法:解决办法:1)把代码)把代码System.setSecurityManager(new RMISecurityManager();去掉,不设置安全管理器去掉,不设置安全管理器2)修改)修改JRE的安全策略文件,在的安全策略文件,在Eclipse中用中用JDK是是c:Javajdk1.5.0_06,相应的安全策略文件就是相应的安全策略文件就是c:javajdk1.5.0_06jrelibsecurityjava.policy,计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室五、第二个例题五、第二个例题1.例题例题2:城市信息服务器:城市信
23、息服务器城市信息服务器提供某一城市人口和温度的查询,客户通城市信息服务器提供某一城市人口和温度的查询,客户通过输入城市名可以获取该城市的人口数和温度等信息。过输入城市名可以获取该城市的人口数和温度等信息。u简单代码实现简单代码实现定定义远程接口:程接口:City.java实现远程接口:程接口:CityImpl.java开开发客客户端程序:端程序:CityApp.javau运行该程序:运行该程序:编译上述三个上述三个类文件文件产生生桩和架构和架构启启动RMI注册注册运行服运行服务器和客器和客户程序程序计算机科学与技术学院网络工程教研室计算机科学与技术学院网络工程教研室1.例题例题2:城市信息服务
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 网络 编程 技术 第七
限制150内