第三章软件体系结构风格要点课件.ppt
《第三章软件体系结构风格要点课件.ppt》由会员分享,可在线阅读,更多相关《第三章软件体系结构风格要点课件.ppt(98页珍藏版)》请在三一办公上搜索。
1、1,第三章 软件体系结构风格分布式体系结构,2,分布式软件体系结构产生背景,在集中式计算技术时代广泛使用的是大型机/小型机计算模型。它是通过一台物理上与宿主机相连接的非智能终端来实现宿主机上的应用程序。 20世纪80年代以后,集中式结构逐渐被以PC机为主的微机网络所取代。个人计算机和工作站的采用,永远改变了协作计算模型,从而导致了分散的个人计算模型的产生。,3,分布式软件体系结构产生背景,它们构建在大的或小的网络环境及某种组合上,形成了分布式系统。在分布式系统中,数据、过程、接口等构件被分布到网络的多个端点,支持这些构件所需的计算也部署到分布环境的计算机上。,4,分布式系统是当前软件开发的重要
2、方向,分布式软件系统直接反映了现实世界中的分别性,例如当前许多业务处理流程通常呈现一种分布式运作方式。改进某些应用程序的运行性能,使它们比单进程的集中式更具有效率。软件的分别性能充分利用额外的计算资源分布式系统增强了信息的互联互通和各主体之间的协作关系,增强了整个系统的计算能力,5,分布式系统是当前软件开发的重要方向,增强了系统的可伸缩性和容错能力分布式系统,尤其是基于网络的体系结构,可共享异地昂贵的外部设备,把一些应用构件和服务委托在具有处理属性的主机上运行,6,三类分布式系统,局域网文件服务器结构客户/服务器体系结构(2层和N层)基于Web的计算,7,一般系统的主要层次,数据存储层数据处理
3、层应用逻辑层表现逻辑层表现层,8,局域网文件服务器体系结构,服务器仅装载了数据层,系统应用的其他层都在客户端实现例如,Access数据库存储在服务器上,但每台使用数据库的计算机必须安装Access应用程序,并从那里执行。,9,局域网文件服务器体系结构,当用户发送一个请求给文件服务器时,文件服务器会从数据库中找到相应的表,传送给客户端,同时对所选表加锁,直到客户端返回表为止。客户端采用本地程序对表进行修改、读取或其他处理,然后再把表返回文件服务器。,10,文件服务器体系结构的适用领域,文件服务器体系结构仅对较少的小型数据库应用是可行的。,11,文件服务器体系结构缺点,客户端和服务器之间需要移动大
4、量不必要的数据,降低了应用性能客户端必须相当健壮。客户端做了几乎所有的工作,而且必须有足够的磁盘空间来存储下载的表容易破坏数据的完整性对环境的变化及用户需求变革的适应性差,一旦发生变化,客户端和服务器端的应用程序都必须修改,增加了维护的工作量,12,客户机/服务器体系结构,客户机/服务器(Client/Server)是一种广泛流行的分布计算软件体系结构,经历了三种结构的演化,两层分布式表现结构、两层分布式数据结构和N层分布式数据和应用结构,13,分布式表现结构,为了克服文件服务器结构中的客户端的超量负载和网络间大数据量传输,同时改进结构的动态适应性,把应用逻辑层和数据处理层从客户端剥离出来,配
5、置在服务器端,构成了分布式表现的C/S体系结构。应用逻辑或数据发生变化时,应修改服务器端的应用程序,14,分布式表现结构,利于基于文件服务器体系结构的现存系统的改造利用易于使这些系统的有效生命期得到延长,15,两层分布式数据结构,数据和数据处理放在服务器上,应用逻辑、表现逻辑和表现层放在客户端。是经典的两层C/S体系结构。充分挖掘使用了客户端的计算能力,并使得数据库维护方便。,16,C/S的基本概念,C/S软件体系结构是基于资源不对等,且为实现共享而提出来的,是20世纪90年代成熟起来的技术,C/S体系结构定义了工作站如何与服务器相连,以实现数据和应用分布到多个处理机上。 C/S体系结构有三个
6、主要组成部分:数据库服务器、客户应用程序和网络。,17,C/S的体系结构,18,服务器的任务分配,数据库安全性的要求;数据库访问并发性的控制;数据库前端的客户应用程序的全局数据完整性规则;数据库的备份与恢复。,19,客户端的任务分配,提供用户与数据库交互的界面;向数据库服务器提交用户请求并接收来自数据库服务器的信息;利用客户应用程序对存在于客户端的数据执行应用逻辑要求。,20,C/S的处理流程,21,C/S体系结构的优点,C/S 体系结构具有强大的数据操作和事务处理能力,模型思想简单,易于人们理解和接受。系统的客户应用程序和服务器构件分别运行在不同的计算机上,系统中每台服务器都可以适合各构件的
7、要求,这对于硬件和软件的变化显示出极大的适应性和灵活性,而且易于对系统进行扩充和缩小。,22,C/S体系结构的优点,系统中的功能构件充分隔离客户应用程序的开发集中于数据的显示和分析数据库服务器的开发则集中于数据的管理不必在每一个新的应用程序中都要对一个DBMS进行编码。将大的应用处理任务分布到许多通过网络连接的低成本计算机上,以节约大量费用。,23,C/S体系结构的缺点,开发成本较高客户端程序设计复杂信息内容和形式单一用户界面风格不一,使用繁杂,不利于推广使用软件移植困难软件维护和升级困难新技术不能轻易应用,24,C/S N层体系结构,在客户端和服务器之间加入一层或多层服务器。,25,第三章
8、软件体系结构风格三层客户/服务器风格,26,三层C/S风格的体系结构,27,三层C/S的处理流程,处理流程,28,C/S的处理流程,29,三层C/S的物理结构,30,三层C/S的优点,应用的各层可以并行开发,可以选择各自最适合的开发语言。利用功能层有效地隔离开表示层与数据层,未授权的用户难以绕过功能层而利用数据库工具或黑客手段去非法地访问数据层,为严格的安全管理奠定了坚实的基础。,31,三层C/S的优点,允许合理地划分三层结构的功能,使之在逻辑上保持相对独立性,能提高系统和软件的可维护性和可扩展性。允许更灵活有效地选用相应的平台和硬件系统,使之在处理负荷能力上与处理特性上分别适应于结构清晰的三
9、层;并且这些平台和各个组成部分可以具有良好的可升级性和开放性。,32,三层C/S的优点,把应用的业务逻辑与用户界面分开,将商业逻辑放在经过合理任务划分与物理部署后的中间层应用服务器上,从而客户程序通过中间层简介访问数据库,客户端修改不影响服务器客户数可以充分扩展,如果需要修改应用程序代码,只需对中间层应用服务器进行修改,而不用修改成千上万的客户端应用程序。,33,三层C/S要注意的问题,三层C/S结构各层间的通信效率若不高,即使分配给各层的硬件能力很强,其作为整体来说也达不到所要求的性能。设计时必须慎重考虑三层间的通信方法、通信频度及数据量。这和提高各层的独立性一样是三层C/S结构的关键问题。
10、,34,浏览器/服务器风格,浏览器/服务器(B/S)风格就是上述三层应用结构的一种实现方式,其具体结构为:浏览器/Web服务器/数据库服务器。,35,浏览器/服务器风格,B/S体系结构主要是利用不断成熟的WWW浏览器技术,结合浏览器的多种脚本语言,用通用浏览器就实现了原来需要复杂的专用软件才能实现的强大功能,并节约了开发成本。从某种程度上来说,B/S结构是一种全新的软件体系结构。,36,浏览器/服务器风格的体系结构,37,浏览器/服务器风格的优点,基于B/S体系结构的软件,系统安装、修改和维护全在服务器端解决。用户在使用系统时,仅仅需要一个浏览器就可运行全部的模块,真正达到了“零客户端”的功能
11、,很容易在运行时自动升级。,38,浏览器/服务器风格的优点,B/S体系结构还提供了异种机、异种网、异种应用服务的联机、联网、统一服务的最现实的开放性基础。,39,浏览器/服务器风格的缺点,B/S体系结构缺乏对动态页面的支持能力,没有集成有效的数据库处理功能。B/S体系结构的系统扩展能力差,安全性难以控制。,40,浏览器/服务器风格的缺点,采用B/S体系结构的应用系统,在数据查询等响应速度上,要远远地低于C/S体系结构。B/S体系结构的数据提交一般以页面为单位,数据的动态交互性不强,不利于在线事务处理(OLTP)应用。OLTP是在线事务处理。比如收银台就像是OLTP,因为不断有数据的录入(或是修
12、改);OLTP就是数据库数据一直在变动、更新的,41,第三章 软件体系结构风格公共对象请求代理结构,42,对象管理结构,公共对象请求代理结构CORBA(Common Object Request Broker Architecture)是一种独立于语言和软件/硬件平台的软件构件模型。,43,CORBA的构成,CORBA主要由对象请求代理、公共对象服务、通用设施和应用接口组成。,44,对象请求代理ORB,请求代理是建立基于分布式对象的应用程序的基础,使得分布式对象之间能够透明的发送请求或接受响应在CORBA中,所有的通信都通过ORB进行,因而无论一个对象是本地的还是远程的,对于与之进行通信的其他
13、对象来说都是等价的CORBA保证了异构和同构环境中对象的可移植性和可互操作性ORB独立于实现对象的特定平台与技术,客户程序无需知道如何与对象通信、如何激活对象、对象如何实现、如何查找对象,45,对象请求代理ORB,请求代理是建立基于分布式对象的应用程序的基础,使得分布式对象之间能够透明的发送请求或接受响应对象请求代理ORB规定了分布对象的接口定义和语言映射、实现了对象间的透明通信和互操作,是分布对象的“软总线”在ORB上定义了并发服务、命名服务、时间服务、安全服务等多样公共服务;通用设施定义了构件框架,为领域对象提供可使用的共享服务,规定领域对象有效协作所需的规则。,46,CORBA对象服务,
14、对象服务是对象管理体系结构OMA定义的一系列独立于应用领域的服务CORBA服务是开发分布式应用所必需的模块,用来提供基本ORB功能之上的更高系统级服务。主要处理核心系统级功能,如异步事件管理、持久性和事务、安全性、并发、命名、消息接发以及目录服务,这些服务要么是基于CORBA的应用程序的基础,要么用于为应用程序提供可互操作性,形成了构件高级工具和业务功能的框架,47,CORBA对象服务,对象服务的本职是将覆盖对象整个生存期的对象管理任务标准化,例如对象服务提供的功能包括了创建对象、对象访问控制、查找对象、维持对象间关系等这种标准化可导致不同应用程序的一致性,并提高软件开发者的生产率,48,CO
15、RBA对象服务,对象服务规范包含在CORBA服务的公共服务规范中,服务规范主要处理各种服务,并定义IDL接口,以及非形式化的描述这些接口的语义这些服务独立于应用领域,包括:命名服务、事件服务、持久对象、并发控制、外表化、许可机制、查询、属性、安全性、时间、对象收集、交易服务等服务的规范,49,CORBA通用设施,通用设施(Common Facilities)是IDL定义的、向终端用户应用程序提供的一组服务接口的集合。通用设施可用于大多数应用领域,包括分布式文档设施、打印设施、数据库设施、电子邮件设施等。,50,CORBA应用程序接口,应用程序对象位于整个OMA参考模型的最高层。它们不是由OMG
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 第三 软件 体系结构 风格 要点 课件
链接地址:https://www.31ppt.com/p-1526233.html