Page1BeijingUniversityofPostsandTelecommunications分布计算环境邹华北京邮电大学网络技术研究院2014.9Page2Page2BeijingUniversityofPostsandTelecommunicationsPage3Page3BeijingUniversityofPostsandTelecommunications分布式系统中的面向对象技术开放分布式处理ODPCORBA技术主要内容Page4Page4BeijingUniversityofPostsandTelecommunications分布式系统中的面向对象技术开放式分布处理ODPCORBA技术主要内容Page5Page5BeijingUniversityofPostsandTelecommunications传统的面向对象技术分布式系统对传统对象模型的影响实现分布式对象模型的机制分布式系统中的面向对象技术Page6Page6BeijingUniversityofPostsandTelecommunications面向对象技术面向对象技术已在软件生存期的各个阶段取代传统的结构化方法,成为当前软件开发的主流技术。OO的基本思想从现实世界中客观存在的事务(即对象)出发来构造软件系统,并在系统构造中尽可能利用人类的自然思维方式。程序对象+相互关系重要特征:封装、继承和多态。面向对象的开发过程实际上是一个建模过程。强调的是复用。先进的分布式软件体系结构必须与面向对象技术结合在一起,从而可分享面向对象技术带来的众多好处。Page7Page7BeijingUniversityofPostsandTelecommunications传统的面向对象技术分布式系统对传统对象模型的影响实现分布式对象模型的机制分布式系统中的面向对象技术Page8Page8BeijingUniversityofPostsandTelecommunications分布式系统对传统对象模型的影响传统的对象与访问该对象的程序只能存在于同一进程中,客户进程不可能直接访问异地服务进程中的常规对象传统对象的关注点:封装和通过继承对实现进行重用封装提供了一种将对象实现细节与其它对象屏蔽开的严格方法,可以大大缓解在面向过程系统中较突出的维护问题。继承提供了一种重用对象实现的简便方法分布式环境要求更好的可插入性:不太关注于直接重用代码,而是要求能够利用远程所实现的服务。要求另一层次上的封装,即只需暴露公用接口对象==〉组件Page9Page9BeijingUniversityofPostsandTelecommunications分布式对封装性的影响在分布式对象系统中,对象不仅要屏蔽有关的算法和数据结构,还需要屏蔽“系统是分布的”这一特性,提供分布透明性。位置透明性:用户不必关心对象位于何处访问透明性:可用一致的方式访问不同类型的机器上的对象持久透明性:对象所处的状态既可以是活动的,也可以是静止的重定位透明性:对象的位置可以变化而不影响对它的调用迁移透明性:系统内部可以迁移对象的位置失败透明性:屏蔽被访问对象的失败及恢复过程(容错)事务处理透明性:与事务处理相关的调度、监控和恢复复制透明性:用户不知道有多少个对象副本存在Page10Page10BeijingUniversityofPostsandTelecommunications分布式对继承性的影响问题:分布对象计算系统中都不支持跨站点的继承性,因为实现代价太大解决:把对象分为接口和对象实现。接口由接口定义语言IDL来描述,对象实现的方式则根据具体的编程语言而定接口:描述使用该对象的方法。由该对象所能提供的操作的说明组成对象实现:实际构成该对象所提供的服务。它定义了与对象有关的数据的格式和用于管理这些数据的服务。Page11Page11BeijingUniversityofPostsandTelecommunications分布式对继承性的影响分布式对象继承机制的实现:从接口继承出发系统首先根据接口的继承关系生成接口的继承关系图,当客户请求某一个接口中所描述的某个服务时,如果系统检查到与该服务所对应的对象实现不存在时,根据接口的继承关系图,向客户返回一个能够提供该服务,并且相应的对象实现又存在的对象的访问信息Page12Page12BeijingUniversityofPostsandTelecommunications分布式对对象引用的影响对象引用用于在系统中标识一个对象,客户可以根据它所知道的对象引用来与相应的对象建立连接,从而访问该对象集中式系统中:对象引用由指向该对象所在的内存地址的指针来表示分布式系统中:对象引用需要由一个较复杂的数据结构来表示。需要充分考虑到由系统的分布所带来的一些问题,如网络协议、网络地址和对象的迁移等Page13Page13BeijingUniversityofPostsandTelecommunicationsaremoteobjectreferencemustbeuniqueinthedistributedsystem.thefirsttwofieldslocatetheobjectunlessmigrationorre-activationinanewprocesscanhappenthefourthfieldidentifiestheobjectwithintheprocessitsinterfacetellsthereceiverwhatmethodsithas(e.g.classMethod)aRemoteobjectreferencemaybeInternetaddressportnumbertimeobjectnumberinterfaceofremoteobject32bits32bits32bits32bitsPage14Page14BeijingUniversityofPostsandTelecommunications如何获得一个对象引用1.生成对象:对其他对象调用一个对象生成请求,返回这个新生成对象的对象引用2.目录服务:通过调用查找服务来得到对象引用命名服务–通过对象名称得到对象引用交易服务--通过对象性质得到对象引用3.字符串转换:一个应用请求ORB将一个对象引用转换成字符串并保存到文件或数据库中,以后再取出通过ORB转换回对象引用。Page15Page15BeijingUniversityofPostsandTelecommunications传统的面向对象技术分布式系统对传统对象模型的影响实现分布式对象模型的机制分布式系统中的面向对象技术Page16Page16BeijingUniversityofPostsandTelecommunications实现分布式对象模型的机制分布式调用:通过把相应的请求信息传递给远端对象来完成,提供位置透明性和访问透明性分布式系统中的通用服务(系统级服务)Page17Page17BeijingUniversityofPostsandTelecommunications接口(Interface):接口是系统中用来定义分布式对象能力的约定。对象引用(ObjectReference)对象引用是在客户程序的编程语言或脚本环境内用来引用分布式对象的实例。对象引用不同于OO中的对象指针概念对象创建(ObjectCreation)分布式对象系统必须为创建一个新的分布式对象实例提供一种机制。工厂(factory)是一种特殊的分布式对象类型,常用来创建其它的分布式对象。面向对象的分布式调用相关概念Page18Page18BeijingUniversityofPostsandTelecommunications对象调用(ObjectInvocation)分布式对象系统必须为分布式对象的调用提供一种机制对象撤销(ObjectDestruction)分布式对象系统必须提供一种机制,一旦一个分布式对象的实例不再被使用,就必须及时的将它从系统中删除。COM提供了分布式引用计数和垃圾回收方法CORBA没有对此提供系统级支持EJB明确定义了各种Bean的生命周期管理策略WebService没有对此提供系统级支持。面向对象的分布式调用相关概念(续)Page19Page19BeijingUniversityofPostsandTelecommunications除了通信协议外,分布式系统还会用到一些可能很复杂,但又会经常重复使用的服务。如安全性管理、事务处理等。一个平台或体系结构所显式提供的服务越多,开发者就越容易在更短的时间内开发出高质量的分布式系统。有了平台提供的服务,开发者可以将更多的精力集中于系统的商业逻辑(如EJB)可通过交易功能提供通用服务。e.g.事务处理服务、时钟服务、管理服务、定时服务、安全服务,email服务…分布式系统中的系统级服务Page20Page20BeijingUniversityofPostsandTelecommunications命名服务(Naming)在分布式系统中,命名服务提供了一种定位分布式对象的机制。监视(Monitoring)监视服务不仅可以监视系统的运行状态,而且当需要操作人员参与时可以发出警告信息。许可(Licensing)许可服务用于确认分布式系统的用户已经购买了适当的使用许可。持久性(Persistence)持久性服务提供一种统一的机制,使得分布式对象可以通过持久的数据存储来保存、更新和恢复它的状态常见的服务(1)Page21Page21BeijingUniversityofPostsandTelecommunications安全性(Security)安全性服务确保于分布式对象的通信是安全的,并确认相应的用户具有适当的权限。事务(Transaction)事务服务能够确保一个事务或者完全完成,或者完全放弃。在企业系统中,事务定义了工作的原子级(atomic)单元。分布式事务处理就是一个跨越多台计算机的单个工作单元。消息处理(Messaging)消息处理服务提供异步编程模式。异步模式在很多应用中都需要。常见的服务(2)Page22Page22BeijingUniversityofPostsandTelecommunications分布式垃圾回收(Distributedgarbagecollection)当一个程序不再使用分布式对象时,分布式垃圾回收服务会自动释放分布式对象所占用的存储单元。资源管理(ResourceManagement)一般来说,资源管理器按照使可伸缩性最大化的方式来管理分布式对象,即支持大量的客户程序同分布式对象在短时间内进行交互的能力。常见的服务(3)Page23Page23BeijingUniversityofPostsandTelecommunications分布对象技术三大流派OMG的CORBA:CommonObjectRequestBrokerArchitecture微软的COM/DCOM:(Distributed)ComponentObjectModel(在Internet上,.NET框架,基于XML的WebService)SUN的EJB/J2EEPage24Page24BeijingUniversityofPostsandTelecommunications分布对象技术的实质性进步:使面向对象技术能够在异构的网络环境中得以全面、彻底、方便的实施有效地控制系统的开发、管理、维护的复杂性分布对象的对象引用:具有网络数据;发布和获取分布式对象技术的核心概念:分布透明性小结Page25BeijingUniversityofPostsandTelecommunications分布计算环境邹华北京邮电大学网络技术研究院2014.9Page26Page26BeijingUniversityofPostsandTele