欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    第三章软件体系结构风格要点课件.ppt

    • 资源ID:1526233       资源大小:1.01MB        全文页数:98页
    • 资源格式: PPT        下载积分:16金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要16金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    第三章软件体系结构风格要点课件.ppt

    1,第三章 软件体系结构风格分布式体系结构,2,分布式软件体系结构产生背景,在集中式计算技术时代广泛使用的是大型机/小型机计算模型。它是通过一台物理上与宿主机相连接的非智能终端来实现宿主机上的应用程序。 20世纪80年代以后,集中式结构逐渐被以PC机为主的微机网络所取代。个人计算机和工作站的采用,永远改变了协作计算模型,从而导致了分散的个人计算模型的产生。,3,分布式软件体系结构产生背景,它们构建在大的或小的网络环境及某种组合上,形成了分布式系统。在分布式系统中,数据、过程、接口等构件被分布到网络的多个端点,支持这些构件所需的计算也部署到分布环境的计算机上。,4,分布式系统是当前软件开发的重要方向,分布式软件系统直接反映了现实世界中的分别性,例如当前许多业务处理流程通常呈现一种分布式运作方式。改进某些应用程序的运行性能,使它们比单进程的集中式更具有效率。软件的分别性能充分利用额外的计算资源分布式系统增强了信息的互联互通和各主体之间的协作关系,增强了整个系统的计算能力,5,分布式系统是当前软件开发的重要方向,增强了系统的可伸缩性和容错能力分布式系统,尤其是基于网络的体系结构,可共享异地昂贵的外部设备,把一些应用构件和服务委托在具有处理属性的主机上运行,6,三类分布式系统,局域网文件服务器结构客户/服务器体系结构(2层和N层)基于Web的计算,7,一般系统的主要层次,数据存储层数据处理层应用逻辑层表现逻辑层表现层,8,局域网文件服务器体系结构,服务器仅装载了数据层,系统应用的其他层都在客户端实现例如,Access数据库存储在服务器上,但每台使用数据库的计算机必须安装Access应用程序,并从那里执行。,9,局域网文件服务器体系结构,当用户发送一个请求给文件服务器时,文件服务器会从数据库中找到相应的表,传送给客户端,同时对所选表加锁,直到客户端返回表为止。客户端采用本地程序对表进行修改、读取或其他处理,然后再把表返回文件服务器。,10,文件服务器体系结构的适用领域,文件服务器体系结构仅对较少的小型数据库应用是可行的。,11,文件服务器体系结构缺点,客户端和服务器之间需要移动大量不必要的数据,降低了应用性能客户端必须相当健壮。客户端做了几乎所有的工作,而且必须有足够的磁盘空间来存储下载的表容易破坏数据的完整性对环境的变化及用户需求变革的适应性差,一旦发生变化,客户端和服务器端的应用程序都必须修改,增加了维护的工作量,12,客户机/服务器体系结构,客户机/服务器(Client/Server)是一种广泛流行的分布计算软件体系结构,经历了三种结构的演化,两层分布式表现结构、两层分布式数据结构和N层分布式数据和应用结构,13,分布式表现结构,为了克服文件服务器结构中的客户端的超量负载和网络间大数据量传输,同时改进结构的动态适应性,把应用逻辑层和数据处理层从客户端剥离出来,配置在服务器端,构成了分布式表现的C/S体系结构。应用逻辑或数据发生变化时,应修改服务器端的应用程序,14,分布式表现结构,利于基于文件服务器体系结构的现存系统的改造利用易于使这些系统的有效生命期得到延长,15,两层分布式数据结构,数据和数据处理放在服务器上,应用逻辑、表现逻辑和表现层放在客户端。是经典的两层C/S体系结构。充分挖掘使用了客户端的计算能力,并使得数据库维护方便。,16,C/S的基本概念,C/S软件体系结构是基于资源不对等,且为实现共享而提出来的,是20世纪90年代成熟起来的技术,C/S体系结构定义了工作站如何与服务器相连,以实现数据和应用分布到多个处理机上。 C/S体系结构有三个主要组成部分:数据库服务器、客户应用程序和网络。,17,C/S的体系结构,18,服务器的任务分配,数据库安全性的要求;数据库访问并发性的控制;数据库前端的客户应用程序的全局数据完整性规则;数据库的备份与恢复。,19,客户端的任务分配,提供用户与数据库交互的界面;向数据库服务器提交用户请求并接收来自数据库服务器的信息;利用客户应用程序对存在于客户端的数据执行应用逻辑要求。,20,C/S的处理流程,21,C/S体系结构的优点,C/S 体系结构具有强大的数据操作和事务处理能力,模型思想简单,易于人们理解和接受。系统的客户应用程序和服务器构件分别运行在不同的计算机上,系统中每台服务器都可以适合各构件的要求,这对于硬件和软件的变化显示出极大的适应性和灵活性,而且易于对系统进行扩充和缩小。,22,C/S体系结构的优点,系统中的功能构件充分隔离客户应用程序的开发集中于数据的显示和分析数据库服务器的开发则集中于数据的管理不必在每一个新的应用程序中都要对一个DBMS进行编码。将大的应用处理任务分布到许多通过网络连接的低成本计算机上,以节约大量费用。,23,C/S体系结构的缺点,开发成本较高客户端程序设计复杂信息内容和形式单一用户界面风格不一,使用繁杂,不利于推广使用软件移植困难软件维护和升级困难新技术不能轻易应用,24,C/S N层体系结构,在客户端和服务器之间加入一层或多层服务器。,25,第三章 软件体系结构风格三层客户/服务器风格,26,三层C/S风格的体系结构,27,三层C/S的处理流程,处理流程,28,C/S的处理流程,29,三层C/S的物理结构,30,三层C/S的优点,应用的各层可以并行开发,可以选择各自最适合的开发语言。利用功能层有效地隔离开表示层与数据层,未授权的用户难以绕过功能层而利用数据库工具或黑客手段去非法地访问数据层,为严格的安全管理奠定了坚实的基础。,31,三层C/S的优点,允许合理地划分三层结构的功能,使之在逻辑上保持相对独立性,能提高系统和软件的可维护性和可扩展性。允许更灵活有效地选用相应的平台和硬件系统,使之在处理负荷能力上与处理特性上分别适应于结构清晰的三层;并且这些平台和各个组成部分可以具有良好的可升级性和开放性。,32,三层C/S的优点,把应用的业务逻辑与用户界面分开,将商业逻辑放在经过合理任务划分与物理部署后的中间层应用服务器上,从而客户程序通过中间层简介访问数据库,客户端修改不影响服务器客户数可以充分扩展,如果需要修改应用程序代码,只需对中间层应用服务器进行修改,而不用修改成千上万的客户端应用程序。,33,三层C/S要注意的问题,三层C/S结构各层间的通信效率若不高,即使分配给各层的硬件能力很强,其作为整体来说也达不到所要求的性能。设计时必须慎重考虑三层间的通信方法、通信频度及数据量。这和提高各层的独立性一样是三层C/S结构的关键问题。,34,浏览器/服务器风格,浏览器/服务器(B/S)风格就是上述三层应用结构的一种实现方式,其具体结构为:浏览器/Web服务器/数据库服务器。,35,浏览器/服务器风格,B/S体系结构主要是利用不断成熟的WWW浏览器技术,结合浏览器的多种脚本语言,用通用浏览器就实现了原来需要复杂的专用软件才能实现的强大功能,并节约了开发成本。从某种程度上来说,B/S结构是一种全新的软件体系结构。,36,浏览器/服务器风格的体系结构,37,浏览器/服务器风格的优点,基于B/S体系结构的软件,系统安装、修改和维护全在服务器端解决。用户在使用系统时,仅仅需要一个浏览器就可运行全部的模块,真正达到了“零客户端”的功能,很容易在运行时自动升级。,38,浏览器/服务器风格的优点,B/S体系结构还提供了异种机、异种网、异种应用服务的联机、联网、统一服务的最现实的开放性基础。,39,浏览器/服务器风格的缺点,B/S体系结构缺乏对动态页面的支持能力,没有集成有效的数据库处理功能。B/S体系结构的系统扩展能力差,安全性难以控制。,40,浏览器/服务器风格的缺点,采用B/S体系结构的应用系统,在数据查询等响应速度上,要远远地低于C/S体系结构。B/S体系结构的数据提交一般以页面为单位,数据的动态交互性不强,不利于在线事务处理(OLTP)应用。OLTP是在线事务处理。比如收银台就像是OLTP,因为不断有数据的录入(或是修改);OLTP就是数据库数据一直在变动、更新的,41,第三章 软件体系结构风格公共对象请求代理结构,42,对象管理结构,公共对象请求代理结构CORBA(Common Object Request Broker Architecture)是一种独立于语言和软件/硬件平台的软件构件模型。,43,CORBA的构成,CORBA主要由对象请求代理、公共对象服务、通用设施和应用接口组成。,44,对象请求代理ORB,请求代理是建立基于分布式对象的应用程序的基础,使得分布式对象之间能够透明的发送请求或接受响应在CORBA中,所有的通信都通过ORB进行,因而无论一个对象是本地的还是远程的,对于与之进行通信的其他对象来说都是等价的CORBA保证了异构和同构环境中对象的可移植性和可互操作性ORB独立于实现对象的特定平台与技术,客户程序无需知道如何与对象通信、如何激活对象、对象如何实现、如何查找对象,45,对象请求代理ORB,请求代理是建立基于分布式对象的应用程序的基础,使得分布式对象之间能够透明的发送请求或接受响应对象请求代理ORB规定了分布对象的接口定义和语言映射、实现了对象间的透明通信和互操作,是分布对象的“软总线”在ORB上定义了并发服务、命名服务、时间服务、安全服务等多样公共服务;通用设施定义了构件框架,为领域对象提供可使用的共享服务,规定领域对象有效协作所需的规则。,46,CORBA对象服务,对象服务是对象管理体系结构OMA定义的一系列独立于应用领域的服务CORBA服务是开发分布式应用所必需的模块,用来提供基本ORB功能之上的更高系统级服务。主要处理核心系统级功能,如异步事件管理、持久性和事务、安全性、并发、命名、消息接发以及目录服务,这些服务要么是基于CORBA的应用程序的基础,要么用于为应用程序提供可互操作性,形成了构件高级工具和业务功能的框架,47,CORBA对象服务,对象服务的本职是将覆盖对象整个生存期的对象管理任务标准化,例如对象服务提供的功能包括了创建对象、对象访问控制、查找对象、维持对象间关系等这种标准化可导致不同应用程序的一致性,并提高软件开发者的生产率,48,CORBA对象服务,对象服务规范包含在CORBA服务的公共服务规范中,服务规范主要处理各种服务,并定义IDL接口,以及非形式化的描述这些接口的语义这些服务独立于应用领域,包括:命名服务、事件服务、持久对象、并发控制、外表化、许可机制、查询、属性、安全性、时间、对象收集、交易服务等服务的规范,49,CORBA通用设施,通用设施(Common Facilities)是IDL定义的、向终端用户应用程序提供的一组服务接口的集合。通用设施可用于大多数应用领域,包括分布式文档设施、打印设施、数据库设施、电子邮件设施等。,50,CORBA应用程序接口,应用程序对象位于整个OMA参考模型的最高层。它们不是由OMG来标准化的,而是符合传统上对应用程序的认识。应用程序对象为终端用户执行特定的任务,主要为某一类应用或一个特定的应用提供服务,51,对象管理结构,52,CORBA的特点,CORBA在基于网络的分布式应用环境下实现应用软件的集成。CORBA采用并吸收了面向对象技术、分布式计算技术和多层体系结构技术,实现了在分布式应用环境中软件的可复用性、可移植性和互操作性。,53,CORBA的特点,提供“软件总线”机制“软件总线”机制简化了分布式应用系统的复杂性。任何应用只要提供按照CORBA规范定义的一组接口,就可以方便的集成到CORBA系统中。接口规范独立于任何实现语言和环境。因此,客户应用和服务对象之间可以透明的交互运行,实现应用程序在“软件总线”上的即插即用。,54,CORBA的特点,使用代理扩展了客户/服务器的计算模型代理的作用是:完成对客户发出的抽象服务请求的映射,自动发现并找到服务器,自动设定路由,实现服务器程序的执行客户和服务器完全分离。这和传统的客户/服务器方式有很大的不同客户不再与服务器直接联系,而是与代理发生联系。这样,客户和服务器都易于维护、修改,55,CORBA的特点,使用IDL定义接口通过从IDL到具体编程语言映射的方式,CORBA对象可以用任何一种CORBA软件开发商所支持的语言,如C,C+,Java,Ada和Smalltalk等,56,CORBA的特点,引入中间件作为事务代理,用于传递客户提出的服务请求及得到的服务结果。实现客户程序与对象实现之间的完全分离,客户端程序不需要了解对象的具体实现、操作平台和位置信息。提供“软总线”功能,对于任何环境、任何程序设计语言,只要遵循接口规范,就可以集成到已有的分布式系统中来。,57,CORBA的特点,采用接口技术,使得软件总体设计、详细设计、代码编写以及维护等方面可以独立进行,同时又可以保证代码的一致性。采用面向对象技术,使得在软件开发中能很好的实现信息封装、代码复用。,58,基于Java平台的分布式计算,Sun公司于1995年正式推出Java技术。由于Java在网络计算领域中的跨平台优势,Java已从一种编程语言逐渐发展成一个软件开发平台,被计算机业界广泛接受,并被越来越多的标准化组织采纳为国际标准或行业标准Sun于1996年发布了JDK1.0,1997年发布了JDK1.1,1998年发布了JDK1.2(Java 2),2000年JDK1.3,目前是JDK1.6,59,基于Java平台的分布式计算,Java 2的出现改变了Personal Java和Embedded Java的分法,改分为Java 2 Platform Enterprise Edition(J2EE),企业级计算、电子商务等领域的服务器应用Java 2 Platform Standard Edition(J2SE),一般的个人计算机Java 2 Platform Micro Edition(J2ME),消费性电子产品Sun ONE(Sun OpenNetwork Environment)是Sun公司2001年发布的,用于实现异构网络环境下的分布式计算的软件体系结构,用用于实现Web Service的平台,60,Java RMI,在进行本地或远程机器上的进程间通信、远程执行代码时,有多种技术可用。最早且最常用的方法是在进程之间建立通信链路。通过这条链路,一个进程可以把某些操作和数据按照约定的格式发送给另一个进程接收进程在解码后,执行响应的操作,并用同样的方法将结果返回给发起进程套接字编程就采用了这种方法,61,Java RMI,但是,采用这种方法时,程序员必须给每个应用程序创建一个表示操作和数据的编码方式。这种做法还将引入两种不同的典型编程方法程序设计语言的过程调用/参数传递模型用于套接字的编程的命令模型 加大了开发难度远程机器之间的数据格式和字节排序顺序都可能不同,这种数据格式的平台相关性增大了通信的复杂性,62,Java RMI,另一种方法是远程过程调用(Remote Procedure Call)使用这种方法,远程进程间的通信和调用能够以一种类似于本地过程调用和参数传递那样的方式进行,这使得程序设计中能使用统一的编程风格。但是数据格式和字节排列顺序的问题仍然存在,而且RPC是一种面向处理的程序风格,不适用于面向对象的系统设计方案,63,Java RMI,Java 远程方法调用,Java RMI(Java Remote Method Invocation)是以同构的Java虚拟机环境为基础的一种解决方案Java RMI利用Java对象模型的优点,是一种纯Java的分布式应用核心解决方案,64,Java语言支持分布式对象的目标,在保留大部分Java语言对象语义的同时,用较为自然的方式将分布式对象模型集成到Java语言中在不同的虚拟机上支持对象的无缝远程调用支持从服务器到applet的回调使分布式对象模型和本地Java对象模型的差异明朗化为远程对象提供各种引用语义,例如非持久引用、持久引用和惰性激活实现安全管理器和类加载器提供的安全可靠的Java环境,65,Java RMI概述,RMI是JSDK的一部分,是一个支持分布式计算应用程序的远程方法调用和返回的API在RMI中,任何一个可以被其他Java虚拟机调用其方法的对象称为远程对象(Remote Object)。远程对象是网络对象,调用它们的客户或其他远程对象的地理位置是透明的。既可能是位于同一个地址空间内,也可能是跨越互联网的调用RMI在处理本地调用和分布式对象的方法调用时,使用几乎相同的编程模型,并假设调用方法和被调用方法均使用Java语言,66,Java RMI的编组和解组,RMI允许通过网络传递参数,包括Java基本元和对象编组和解组是使参数在被请求机器上可以使用的处理方法,它将参数打包、拆包,从而使得它们可应用于不同的环境,67,Java RMI参数传递,RMI允许两种方法传递参数:值传递和引用传递值传递时,在远程主机上的另一个进程创建新对象,并将参数复制到新对象中。引用传递时,远程主机收到的是原对象的一个引用,而不是具体拷贝。所以它不在另一个进程中创建对象,对象仍留在原地,并进行远程操作。这些远程操作所做出的修改会影响原始数据,68,Java RMI远程对象和远程接口,RMI就是调用远程对象上远程接口的方法的动作。远程对象由一种或多种远程接口描述。客户可以向位于另一台机器的远程对象发送一条消息,并获得返回结果,就像那些对象位于本地机器一样。远程对象的方法调用与本地对象的方法调用语法相同,69,Java RMI安全性,RMI使用Java内置的安全机制保证下载执行的程序时用户系统的安全RMI使用专门为保护系统免遭恶意Java Applet侵害而设计的安全管理程序,可保护系统和网络免遭潜在的恶意下载程序的破坏。在情况严重时,服务器可拒绝下载任何执行程序,70,Java RMI兼容性,RMI可通过Java的本机方法接口JNI与现有系统进行交互。利用RMI和JNI,就能用Java编写客户端程序,还能使用现有的服务器端程序。使用RMI/JNI与现有服务器连接时,可以有选择的用Java重新编写服务程序的任何部分,并使新的程序充分发挥Java功能。RMI可以利用JDBC,在不修改使用数据库的现有非Java源代码的前提下与现有数据库进行交互,71,Java RMI分布式垃圾收集,72,Java RMI,73,Java RMI,74,Java RMI,75,Java RMI,76,Java RMI,77,Java RMI,78,基于Java平台的分布式计算,79,第三章 软件体系结构风格正交软件体系结构,80,正交软件体系结构的概念,正交软件体系结构由组织层和线索的构件构成。层是由一组具有相同抽象级别的构件构成。线索是子系统的特例,它是由完成不同层次功能的构件组成(通过相互调用来关联),每一条线索完成整个系统中相对独立的一部分功能。,81,正交软件体系结构的线索,每一条线索的实现与其他线索的实现无关或关联很少,在同一层中的构件之间是不存在相互调用的。如果线索是相互独立的,即不同线索中的构件之间没有相互调用,那么这个结构就是完全正交的。,82,正交软件体系结构的框架,83,大型和复杂的软件系统,其子线索可以划分为更低一级的子线索,形成多级正交结构同一层次的构件不允许互相调用,84,系统演化对体系结构的影响,在系统演化过程中,系统需求不断发生变化。在正交软件体系结构中,因线索的正交性,每个需求的变动仅影响某一条线索,不会影响其他线索。这样,把软件需求的变动局部化了,产生的影响也被限制在一定的范围内,容易实现,85,系统演化对体系结构的影响,多级正交结构对于降低软件演化更新的开销是行之有效的适合大型软件开发,特别是MIS领域,86,正交软件体系结构的特征,正交软件体系结构由完成不同功能的n(n 1)个线索(子系统)组成;系统具有m(m 1)个不同抽象级别的层;线索之间是相互独立的(正交的);系统有一个公共驱动层(一般为最高层)和公共数据结构(一般为最低层)。,87,正交软件体系结构的特点,结构清晰,易于理解。由于线索功能相互独立,不进行互相调用,结构简单、清晰,构件在结构图中的位置已经说明它所实现的是哪一级抽象,担负的是什么功能。,88,正交软件体系结构的特点,易修改,可维护性强。由于线索之间是相互独立的,所以对一个线索的修改不会影响到其他线索。系统功能的增加或减少,只需相应的增删线索构件族,而不影响整个正交体系结构,因此能方便地实现结构调整。,89,正交软件体系结构的特点,可移植性强,重用粒度大。因为正交结构可以为一个领域内的所有应用程序所共享,这些软件有着相同或类似的层次和线索,可以实现体系结构级的重用。,90,第三章 软件体系结构风格异构结构风格,91,体系结构的风格没有定式,软件体系结构风格为大粒度的软件重用提供了机会,然而,体系结构风格的使用却没有一个定式。,92,具体问题,具体分析,对于应用体系结构风格来说,由于观察和考虑问题的角度不同,系统设计师可以有很大的选择余地。而且,不同的软件体系结构具有不同的处理能力的强项和弱点。因此,一个系统的体系结构应该根据实际需要进行选择,要为系统选择或设计某一个体系结构风格,必须根据特定项目的具体特点,进行分析和比较后才能确定。,93,异构软件体系结构,事实上存在一些系统,它们是由这些纯体系结构组合而成,即采用了异构软件体系结构。,94,异构体系结构的组合方式,异构体系结构的组合方式有很多种,例如,可以采用平行的方式,即根据软件各个子系统的结构、功能和性能,为每个类子系统选择相应的体系结构。例如:设计某省工商行政管理系统时,根据子系统的功能把所有子系统划分为两大类,分别是数据处理类和查询类。然后根据子系统的功能选择相应的体系结构,为数据处理类子系统选择了CS结构,为查询类子系统选择了BS结构,95,为什么要使用异构结构,不同的结构有不同的处理能力的强项和弱点,一个系统的体系结构应该根据实际需要进行选择,以解决实际问题。关于软件包、框架、通信以及其他一些体系结构上的问题,目前存在多种标准。即使在某段时间内某一种标准占统治地位,但变动最终是绝对的。,96,为什么要使用异构结构,实际工作中,我们总会遇到一些遗留下来的代码,它们仍有效用,但是却与新系统有某种程度上的不协调。然而在许多场合,将技术与经济综合进行考虑时,总是决定不再重写它们。即使在某一单位中,规定了共享共同的软件包或相互关系的一些标准,仍会存在解释或表示习惯上的不同。,97,C/S与B/S混合之内外有别模型,98,C/S与B/S混合之查改有别模型,

    注意事项

    本文(第三章软件体系结构风格要点课件.ppt)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开