分布对象技术课件_第1页
分布对象技术课件_第2页
分布对象技术课件_第3页
分布对象技术课件_第4页
分布对象技术课件_第5页
已阅读5页,还剩52页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、分布对象技术9/22/20221北京大学北京大学计算机系代亚非第九章 分布对象技术9.1 分布对象技术要解决的基本问题9.2 分布对象技术概论9.3 分布对象的核心概念9.4 分布对象主流技术介绍9.5 分布对象处理技术-发展趋势9.6 分布对象主流技术开发过程29.1 分布对象技术要解决的基本问题以下情况是不是分布式?1、浏览2、两个及其之间的通信3、计算引擎3?B机A机就是支持访问异地对象同一地址空间C+编译器完成连接 C+Main ProgramC+ Object分布对象技术要解决的问题9.1 分布对象技术要解决的基本问题49.1 分布对象技术要解决的基本问题一个分布式系统的例子(原始的

2、方法)电话订购客户1电话订购客户2电话订购客户nWEB服务器 1 WEB服务器 2 中心订购服务器WEB服务器 m Internet.69.1 分布对象技术要解决的基本问题使用多个服务器分割用户电话订购客户1WEB服务器 1 Internet电话订购客户2中心订购服务器1WEB服务器 2 电话订购客户1WEB服务器 1 电话订购客户2中心订购服务器1WEB服务器 2 电话订购客户1WEB服务器 1 电话订购客户2中心订购服务器1WEB服务器 2 79.1 分布对象技术要解决的基本问题问题案例一:如何综合越来越多的数据库资源,以适应不断发展的业务逻辑客户OracleSybaseInformix如

3、何加入综合多个数据库的业务逻辑?如何集成其它非数据库操作的业务逻辑?如何处理“肥客户”应用问题?如何处理用户界面风格多样性?99.1 分布对象技术要解决的基本问题问题案例二如何管理不断接入的新应用管理器N1N2Nk.?109.1 分布对象技术要解决的基本问题汇编语言单机应用开发环境分布式应用开发环境Socket APIFortran语言OOP语言软构件技术RPC分布对象技术119.1 分布对象技术要解决的基本问题我们都听到了哪些词汇?构件模型CORBA/IIOPJava/RMI分布对象ActiveX ControlsRPCCOM/DCOM还有还有.EJB129.2 分布对象技术概论分布计算是近

4、二十年来影响计算机急速发展的最活跃因素之一经历了两种不同的技术路线1. 理想的技术路线(80年代学术界普遍追求的目标) 试图在互连的计算机硬件上部署全新的分布式操 作系统2. 现实的技术路线 (90年代工业界普遍遵守的路线) 在网络计算平台上部署分布计算环境 提供开发工具和公共服务 支持分布式应用 资源共享和协同工作集中式客户/服务器139.2 分布对象技术概论分布式系统比想象的要复杂:1. 异构环境下的应用互操作的问题2. 系统管理问题3. 系统安全的问题4. 传统的面向过程的技术在开发大型软件系统的局限性面向对象技术用于分布式(分布对象技术)标志第二代分布式计算技术进入成熟和蓬勃发展时期.

5、分布式对象技术始于90年代初,已经发展成为当今分布异构环境下建立应用系统集成框架和标准构件的核心技术149.2 分布对象技术概论分布对象技术的核心概念有那些? 1 分布对象的位置对客户透明 2 可以被远程客户应用以方法调用的形式访问 3 分布对象所使用的语言要对客户透明 4. 分布对象运行的系统平台对客户透明 5. 分布对象具有移动性(允许时间,空间,语言,操作平台的差异性)169.2 分布对象技术概论一个应用逻辑A机对象对象对象对象A机一个应用逻辑对象对象对象对象D机C机B机JavaJavaVBC+VB179.2 分布对象技术概论软构件模型的开发的目的是什么? 重用,高层开发,通过工具进行自

6、动化开发,简化开发过程等.软构件模型的开发的手段是什么?软构件开发者: 1.处理底层的实现细节以及与此相关的类. 2.定义构件的基本的体系结构,构件界面的结构,与 其它构件及容器相互作用的机制软构件应用者: 在可视的开发环境将以存在的构件进行简单的组装。199.2 分布对象技术概论软构件模型的例子?OMG的CORBA、Microsoft的COM/DCOM和SUN的Java/EJB。20C+Main ProgramObject AObject AObject AAgent 1Agent 2 网 络 计 算 环 境A的代理对象适配器 ORB9.3 分布对象技术-基本工作原理什么是对象请求代理?支持

7、客户访问异地分布对象的核心机制称为对象请求代理ORB(Object Request Broker)A机一个应用逻辑对象对象对象对象D机C机B机一个应用逻辑A机对象对象对象对象219.3 分布对象技术-基本工作原理客户应用逻辑分布对象代理服务器对象请求分发器分布对象的实现对象请求适配器对象请求感知器网络传输访问ORB服务器构造构架客户构造构架相同的接口相同的接口229.3 分布对象技术-基本工作原理ORBORB客户客户客户客户O1O2OracleO3O4SybaseO5O6InformixO1RO2RO3RO4RO5RO6R虚拟图书馆查询预约服务还书通知通知还/借处理如何管理客户应用预约预约23

8、利用这些服务创建一个新的对象而不必知道对象在哪9.3 分布对象技术-基本工作原理对象服务:支持分布式系统正常工作的各类基本的系统级服务1.名字管理2.事件通告3. 对象事务管理4. 对象生命周期249.3 分布对象技术-基本工作原理应用对象:涉及各种应用软件,它在对象服务和公共设施帮助下完成相应的应用逻辑ORB是一条软总线,把分布式系统中各类对象和应用连接成相互作用的整体269.4 分布对象主流技术分布对象技术的实质性进步: 1. 使面向对象技术能够在异构的网络环境中得以全面,彻底,方便的实施 2. 有效地控制系统的开发,管理,维护的复杂性分布对象的主流技术 1. OMG的CORBA 2. M

9、icrosoft的ActiveX/DCOM 3. SUN的Java/RMI279.4 分布对象主流技术-CORBAORB负责定位服务器对象IDL是建立接口的基础299.4 分布对象主流技术-CORBAIDL Stubs 、IDL Skeleton是由IDL 编译器编译产生的,用于静态调用,有较好的性能和效率。动态调用接口和动态Skeleton用于动态调用,使得即使在编译时不知道可用的服务器和接口消息,也能完成客户与服务器的作用CORBA中的说明语言,称作OMGIDL,用以描述对象的 接口。它本身不是一个可编程语言,但它为程序员提供了语言的独立性,他们不必知道调用者所采用的语言。IDL的词法,语

10、法规则遵从C+的规定,但加入了一些关键词支持分布概念。用接口描述语言(Interface Description Language)编写的对象接口,使得与语言无关的独立性成为可能。309.4 分布对象主流技术-CORBACORBA规范的特点:1. 互操作性:CORBA在客户和服务器之间提供了两层可操作性。一方面它将客户与服务器都抽象为对象,所有功能都封装在对象内部,对外提供简单的接口,可被其它对象以动态或静态方式调用。另一方面,对象间的通信是通过ORB代理实现,对象不必关心细节,由ORB定址发送请求。是ORB对象间的“通信总线”。319.4 分布对象主流技术-CORBA3.跨平台性:由于COR

11、BA规范中定义了IDL语言这一与平台无关的语言,并引入代理(ORB)概念,因此CORBA应用具有较好的跨平台性。2. 提供了软总件机制:所谓软总线是指CORBA规范定义了一组接口规范,任何应用程序,软件系统或工具只要具有与该接口规范相符合的接口定义,就能方便地集成对CORBA系统中,而这个接口规范是独立于任何实现语言和环境。32ORBCLIENTSTUBSSKELETONSSERVERORBIIOPMETHOD REQUESTOBJECT REFERENCESERVANT9.4 分布对象主流技术-CORBACORBA结构一次请求的过程CORBA结构一次请求的过程339.4 分布对象主流技术-C

12、OM/DCOMOLE对象链接和嵌入(Object Linking and Embedding)从用户角度看OLE 1. OLE文档:以文档为中心,OLE集成数据 2. OLE自动化 3. OLE控件:可以被嵌入应用程序中的自包含的, 可重用的组件.COM,DCOM,OLE和ActiveX349.4 分布对象主流技术-COM/DCOM359.4 分布对象主流技术-COM/DCOM36组件对象模型(COM) 结构化存储 跟踪器(永久命名)拖放嵌入剪贴板一致数据传输器(UDT)就地激活(可视编程) 链接OLE自动化OLE控件为将来而建造9.4 分布对象主流技术-COM/DCOM从程序员的角度看OLE

13、OLE文档属性事件379.4 分布对象主流技术-COM/DCOM构件对象模型COM (Component Object Model ) 是一个用于在交互平台上开发客户/服务器应用程序开放结构.COM是微软的构件对象模型,是构件之间实现互操作的二进制标准. COM对象通过接口来显示功能。接口是COM对象与外部世界的一个绑定约定。COM可以用不同语言实现.COM只能运行在WINDOWS平台上COM实现了OLE对象的底层通信,其作用类似于CORBA/ORB389.4 分布对象主流技术-COM/DCOMActiveX是OLE技术和COM技术在Internet网上的一个扩展.但是它的内容更多,它还组成了

14、一系列用来产生丰富的Internet网和多媒体服务.ActiveX文档: 将OLE文档扩展到internet,能够由浏览器打开的word,powerpoint文件ActiveX控件: 将OLE控件扩展到internet。如一个页面包含ActiveX控件,该控件可以自动下载到用户端。ActiveX脚本:将OLE自动化带进internet。可以利用VBScript,JavaScriot,Perl,等语言编写。399.4 分布对象主流技术-COM/DCOM分布式组件对象模型(DCOM或ActiveX/DCOM):被称为网络OLE,是二进制的COM对象在局域,广域网和Internet上的扩展.COM能

15、够使客户在本地处理中透明地访问库中的对象,DCOM允许在远程处理中透明地访问对象。(DCOM的功能实现使得程序员不必编写网络代码,或仅仅知道如何编写网络代码)DCOM基于 (RPC- remote procedure call )工作,它不是一种编程语言,而是一种规范,一种服务,是一种高级网络协议。DCOM是用COM实现的。409.4 分布对象主流技术-COM/DCOMActiveX控件通过底层DCOM进行通信,允许控件互相访问对方公布了的方法,而不必考虑控件是否在一个容器或同一台机器上。ActiveX控件由事件连接在一起, 开发环境支持开发者创建方法,当任何一个构件出发了一个事件,这些方法都

16、被调用.目前有十几家公司提供大量的控件,你可以访问这些公司的WEB站点,下载你需要的ActiveX控件,进行编程: .Windows98和WindowsNT5.0都把DCOM作为操作系统的一部分.419.4 分布对象主流技术-Java/RMIRMI是分布在网络中的各类Java对象之间的进行方法调用的ORB机制.Java语言支持通信的最基本机制是Socket. 但是Socket要求客户和服务器在应用程序级上对交换信息编码的协议达成一致.RPC把通信接口抽象到子程序级,而不是直接与 Socket打交道,但由于不涉及对象,在分布式运算中效果不好.Java/RMI(Remote Method Invo

17、cation)是Java特有的分布式计算技术,它允许运行在一个Java虚拟机上的对象调用运行在另一个Java虚拟机上的对象的方法.Java/RMI429.4 分布对象主流技术-Java/RMIRMI系统的一般结构1. Stub就是代表远程对象的客户方代理,定义远程对象版本所支持的所有接口.2. Skeletons是与服务器方的RRL接口的服务器方构件3. RRL负责维护不与具体Stub或Skeleton模型相关的独立引用协议.这个灵活性使RRL的改变不会影响另外两层.4. 传输层由4个抽象构成: 端点,通道,连接,传送ClientServerRemote Reference LayerStub

18、sTransportSkeletonsApplicationRMI System439.4 分布对象主流技术-Java/RMIRMI系统的一般原理:1. 定位远程对象: RMI的命名工具注册远程对象.2. 和远程对象通信: RMI传输层处理通信细节3. 装载被串对象的字节码: RMI提供了传递数据和 装载一个对象代码 的必要机制Web ServerClient ServerWeb ServerregistryURL protocolRMIRMIURL protocolURL protocolRMI449.4 分布对象主流技术-EJBEJB-(Enterprise JavaBean1.0)是Ja

19、va服务器端构件模型.构件模型通常有客户端构件和服务器端构件构件客户端构件模型JavaBean专门用于处理程序的表示及用户界面的问题.服务器端构件模型 EJB,把构件模型的 开发和中间件联系 起来,面向事务处理 的中间件提供基础 设施.EnterpriseJavaBean容器容器连接EJB服务器客户459.4 分布对象主流技术-EJB为什么要有服务器端构件模型EJB?1. EJB将成为用Java语言开发分布式的、面向对象的企业应用系统的标准构件体系结构,EJB使得通过组合构件得到分布式应用成为可能2. EJB不需要应用开发人员了解底层的事务处理细节,状态管理,多线程,资源共享管理,以及其它底层

20、API细节.3. EJB遵循Java的“write once, run anywhere”的原则.一个EJB可以部署在任何EJB平台上.4. EJB定义了一个协议,使得不同供应商提供的构件能在运行时互操作.5. EJB体系结构和已有的服务器平台,其它的Java APIs, CORBA兼容469.4 分布对象主流技术-EJBEJB与JavaBean的关系1. 客户端的JavaBeans容器可以根据JavaBeans的属性,方法,事件的定义在设计时或运行时对Java Beans进行操作. 一般JavaBeans是可视化的构件. 一个标准的JavaBeans是一个客户端构件,在运行时不能被其它客户机

21、程序存取或操作2. EJB没有用户界面,并完全位于服务器端,EJB可以由多个JavaBeans组成.3. EJB可以和远程的客户程序端通信,并提供一定的功能. 如果不和客户端程序交互,EJB一般不执行具体的功能.4. EJB与JavaBeans的一个重要区别是EJB提供了网络功能.479.4 分布对象主流技术-EJBEJB与CORBA的关系1. 一个CORBA客户机(用CORBA支持的语言些的程序),可以存取基于CORBA的EJB服务器上的构件2. 一个客户机在一个事务过程中可以同时调用CORBA的EJB服务器对象3. 通过IIOP可以使EJB系统和CORBA系统集成.EJB与客户机的关系对于

22、EJB来说,有两种类型的客户机可以使用EJB:1. EJB/CORBA客户机-一个使用EJB APIs的Java客户机.2. 纯CORBA客户机-用CORBA IDL支持的任何语言些的客户机.48EJB的网络计算9.4 分布对象主流技术-EJB客户端在网络计算环境中利用Java的最好途径是由EJB提供服务器端的构件,而由JavaBeans提供客户端构件.499.4 分布对象处理技术-几种构件模型的比较组件:CORBA,JavaBean,ActiveX协议:IIOP, RMI, DCOMCORBA最大的特点是语言中性和跨平台.可以跨越不同网络,不同机器和不同操作系统,实现分布对象之间的互操作.整

23、体功能最强.Java提出了一个概念清晰,结构紧凑的分布计算模型和构件互操作方法,为构件应用开发提供了相当的灵活性,使用上比CORBA方便.但是没有提供分布对象事物管理等服务.微软结合ActiveX/DCOM的开发,配套提出了自己的事务服务器(MTS)和消息队列服务器,加之asp 的使用,以及wizard的可视化编程环境,倍受业界的欢迎.509.4 分布对象处理技术-几种构件模型的比较CORBA的优势在技术,较之COM/DCOM领先至少2-3年; COM/ DCOM的优势在市场能力。目前,只有OMG的技术能够支持大型异构分布式应用的开发,Microsoft的技术尚不能胜任。CORBA技术与Java技术趋于结合,CORBA的互操作性与Java的可移植可移动性将使分布对象技术达到新的高度。519.4 分布对象处理技术-几种构件模型的比较支持跨语言操作支持集成性跨平台操作网络通讯公共服务构件可用性事务处理消息服务安全服务目录服务容错性产品成熟性软件开发商的支持度可扩展性CORBA/ORBActiveX/DCOMEJB/RMIAADACAAAAEAACCBABDCBBCCBABAAABBABCDAA529.5 分布对象处理技术-发展趋势Object web 人们关注的新热点hypertext we

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论