第三章软件体系结构风格(2)_第1页
第三章软件体系结构风格(2)_第2页
第三章软件体系结构风格(2)_第3页
第三章软件体系结构风格(2)_第4页
第三章软件体系结构风格(2)_第5页
已阅读5页,还剩93页未读 继续免费阅读

下载本文档

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

文档简介

1、1第三章第三章 软件体系结构风格软件体系结构风格分布式体系结构分布式体系结构2分布式软件体系结构产生背景产生背景 在集中式计算技术时代广泛使用的是大型机在集中式计算技术时代广泛使用的是大型机/小小型机计算模型。它是通过一台物理上与宿主机相型机计算模型。它是通过一台物理上与宿主机相连接的非智能终端来实现宿主机上的应用程序。连接的非智能终端来实现宿主机上的应用程序。 20世纪世纪80年代以后,集中式结构逐渐被以年代以后,集中式结构逐渐被以PC机机为主的微机网络所取代。个人计算机和工作站的为主的微机网络所取代。个人计算机和工作站的采用,永远改变了协作计算模型,从而导致了分采用,永远改变了协作计算模型

2、,从而导致了分散的个人计算模型的产生。散的个人计算模型的产生。3分布式软件体系结构产生背景产生背景 它们构建在大的或小的网络环境及某种组合上,它们构建在大的或小的网络环境及某种组合上,形成了分布式系统。形成了分布式系统。 在分布式系统中,数据、过程、接口等构件被分在分布式系统中,数据、过程、接口等构件被分布到网络的多个端点,支持这些构件所需的计算布到网络的多个端点,支持这些构件所需的计算也部署到分布环境的计算机上。也部署到分布环境的计算机上。4分布式系统是当前软件开发的重要方向 分布式软件系统直接反映了现实世界中的分别性,例如当前许多业务处理流程通常呈现一种分布式运作方式。 改进某些应用程序的

3、运行性能,使它们比单进程的集中式更具有效率。软件的分别性能充分利用额外的计算资源 分布式系统增强了信息的互联互通和各主体之间的协作关系,增强了整个系统的计算能力5分布式系统是当前软件开发的重要方向 增强了系统的可伸缩性和容错能力 分布式系统,尤其是基于网络的体系结构,可共享异地昂贵的外部设备,把一些应用构件和服务委托在具有处理属性的主机上运行6三类分布式系统 局域网文件服务器结构 客户/服务器体系结构(2层和N层) 基于Web的计算7一般系统的主要层次 数据存储层 数据处理层 应用逻辑层 表现逻辑层 表现层8局域网文件服务器体系结构 服务器仅装载了数据层,系统应用的其他层都在客户端实现 例如,

4、Access数据库存储在服务器上,但每台使用数据库的计算机必须安装Access应用程序,并从那里执行。9局域网文件服务器体系结构 当用户发送一个请求给文件服务器时,文件服务器会从数据库中找到相应的表,传送给客户端,同时对所选表加锁,直到客户端返回表为止。 客户端采用本地程序对表进行修改、读取或其他处理,然后再把表返回文件服务器。10文件服务器体系结构的适用领域 文件服务器体系结构仅对较少的小型数据库应用是可行的。11文件服务器体系结构缺点 客户端和服务器之间需要移动大量不必要的数据,降低了应用性能 客户端必须相当健壮。客户端做了几乎所有的工作,而且必须有足够的磁盘空间来存储下载的表 容易破坏数

5、据的完整性 对环境的变化及用户需求变革的适应性差,一旦发生变化,客户端和服务器端的应用程序都必须修改,增加了维护的工作量12客户机/服务器体系结构 客户机/服务器(Client/Server)是一种广泛流行的分布计算软件体系结构,经历了三种结构的演化,两层分布式表现结构、两层分布式数据结构和N层分布式数据和应用结构13分布式表现结构 为了克服文件服务器结构中的客户端的超量负载和网络间大数据量传输,同时改进结构的动态适应性,把应用逻辑层和数据处理层从客户端剥离出来,配置在服务器端,构成了分布式表现的C/S体系结构。 应用逻辑或数据发生变化时,应修改服务器端的应用程序14分布式表现结构 利于基于文

6、件服务器体系结构的现存系统的改造利用 易于使这些系统的有效生命期得到延长15两层分布式数据结构 数据和数据处理放在服务器上,应用逻辑、表现逻辑和表现层放在客户端。 是经典的两层C/S体系结构。 充分挖掘使用了客户端的计算能力,并使得数据库维护方便。16C/S的基本概念的基本概念 C/S软件体系结构是基于资源不对等,且为实现共享而提出来的,是20世纪90年代成熟起来的技术,C/S体系结构定义了工作站如何与服务器相连,以实现数据和应用分布到多个处理机上。 C/S体系结构有三个主要组成部分:数据库服务器、客户应用程序和网络。17C/S的体系结构的体系结构用户1用户2用户3用户4用户5Print Se

7、rverLink/RxLPT1LPT2COMPower/TXPWROKWIC0ACT/CH0ACT/CH1WIC0ACT/CH0ACT/CH1ETHACTCOL其他公用设备打印机调制解调器InternetIntranet数据库服务器18服务器的任务分配服务器的任务分配 数据库安全性的要求;数据库安全性的要求; 数据库访问并发性的控制;数据库访问并发性的控制; 数据库前端的客户应用程序的全局数数据库前端的客户应用程序的全局数据完整性规则;据完整性规则; 数据库的备份与恢复。数据库的备份与恢复。19客户端的任务分配客户端的任务分配 提供用户与数据库交互的界面;提供用户与数据库交互的界面; 向数据库

8、服务器提交用户请求并接收来自向数据库服务器提交用户请求并接收来自数据库服务器的信息;数据库服务器的信息; 利用客户应用程序对存在于客户端的数据利用客户应用程序对存在于客户端的数据执行应用逻辑要求。执行应用逻辑要求。20C/SC/S的处理流程的处理流程输入数据输出数据请求按钮表示层业务处理开始SQL 请求结束SQL 请求开始业务处理结束数据存取请求业务处理程序业务处理请求和业务处理所需的全部输入数据全部处理结束DBMS 执行SQL数据层业务处理开始数据存取请求业务处理结束数据存取程序数据登录/更新/读取的请求数据登录/更新/读取的结果21C/SC/S体系结构的优点体系结构的优点 C/S 体系结构

9、具有强大的数据操作和事务处理能体系结构具有强大的数据操作和事务处理能力,模型思想简单,易于人们理解和接受。力,模型思想简单,易于人们理解和接受。 系统的客户应用程序和服务器构件分别运行在不系统的客户应用程序和服务器构件分别运行在不同的计算机上,系统中每台服务器都可以适合各同的计算机上,系统中每台服务器都可以适合各构件的要求,这对于硬件和软件的变化显示出极构件的要求,这对于硬件和软件的变化显示出极大的适应性和灵活性,而且易于对系统进行扩充大的适应性和灵活性,而且易于对系统进行扩充和缩小。和缩小。22C/SC/S体系结构的优点体系结构的优点 系统中的功能构件充分隔离系统中的功能构件充分隔离 客户应

10、用程序的开发集中于数据的显示和分析客户应用程序的开发集中于数据的显示和分析 数据库服务器的开发则集中于数据的管理数据库服务器的开发则集中于数据的管理 不必在每一个新的应用程序中都要对一个不必在每一个新的应用程序中都要对一个DBMS进行编码。进行编码。 将大的应用处理任务分布到许多通过网络连将大的应用处理任务分布到许多通过网络连接的低成本计算机上,以节约大量费用。接的低成本计算机上,以节约大量费用。 23C/SC/S体系结构的体系结构的缺点缺点 开发成本较高开发成本较高 客户端程序设计复杂客户端程序设计复杂 信息内容和形式单一信息内容和形式单一 用户界面风格不一,使用繁杂,不利于推广使用用户界面

11、风格不一,使用繁杂,不利于推广使用 软件移植困难软件移植困难 软件维护和升级困难软件维护和升级困难 新技术不能轻易应用新技术不能轻易应用24C/S N层体系结构 在客户端和服务器之间加入一层或多层服务器。25第三章第三章 软件体系结构风格软件体系结构风格三层客户三层客户/服务器风格服务器风格26三层三层C/S风格的体系结构风格的体系结构用户1用户2.用户nInternetIntranet数据库服务器1数据库服务器2应用服务器.27三层三层C/S的处理流程的处理流程处理流程处理流程28C/SC/S的处理流程的处理流程输入数据输出数据请求按钮表示层业务处理开始SQL 请求结束SQL 请求开始业务处

12、理结束数据存取请求业务处理程序业务处理请求和业务处理所需的全部输入数据全部处理结束DBMS 执行SQL数据层业务处理开始数据存取请求业务处理结束数据存取程序数据登录/更新/读取的请求数据登录/更新/读取的结果29三层三层C/S的物理结构的物理结构数据层表示层功能层服务器2客户机服务器1数据层数据层功能层表示层表示层功能层(1)将数据层和功能层放在同一台服务器上(2)将数据层和功能层放在不同的服务器上(3)将功能层放在客户机上30三层三层C/S的优点的优点 应用的各层可以并行开发,可以选择各自最适合应用的各层可以并行开发,可以选择各自最适合的开发语言。的开发语言。 利用功能层有效地隔离开表示层与

13、数据层,未授利用功能层有效地隔离开表示层与数据层,未授权的用户难以绕过功能层而利用数据库工具或黑权的用户难以绕过功能层而利用数据库工具或黑客手段去非法地访问数据层,为严格的安全管理客手段去非法地访问数据层,为严格的安全管理奠定了坚实的基础。奠定了坚实的基础。31三层三层C/S的优点的优点 允许合理地划分三层结构的功能,使之在逻辑上允许合理地划分三层结构的功能,使之在逻辑上保持相对独立性,能提高系统和软件的可维护性保持相对独立性,能提高系统和软件的可维护性和可扩展性。和可扩展性。 允许更灵活有效地选用相应的平台和硬件系统,允许更灵活有效地选用相应的平台和硬件系统,使之在处理负荷能力上与处理特性上

14、分别适应于使之在处理负荷能力上与处理特性上分别适应于结构清晰的三层;并且这些平台和各个组成部分结构清晰的三层;并且这些平台和各个组成部分可以具有良好的可升级性和开放性。可以具有良好的可升级性和开放性。32三层三层C/S的优点的优点 把应用的业务逻辑与用户界面分开,将商业逻辑放在经过合理任务划分与物理部署后的中间层应用服务器上,从而客户程序通过中间层简介访问数据库,客户端修改不影响服务器 客户数可以充分扩展,如果需要修改应用程序代码,只需对中间层应用服务器进行修改,而不用修改成千上万的客户端应用程序。33三层三层C/S要注意的问题要注意的问题 三层三层C/S结构各层间的通信效率若不高,即结构各层

15、间的通信效率若不高,即使分配给各层的硬件能力很强,其作为整使分配给各层的硬件能力很强,其作为整体来说也达不到所要求的性能。体来说也达不到所要求的性能。 设计时必须慎重考虑三层间的通信方法、设计时必须慎重考虑三层间的通信方法、通信频度及数据量。这和提高各层的独立通信频度及数据量。这和提高各层的独立性一样是三层性一样是三层C/S结构的关键问题。结构的关键问题。34浏览器浏览器/ /服务器风格服务器风格 浏览器浏览器/服务器(服务器(B/S)风格就是上述三层应用结)风格就是上述三层应用结构的一种实现方式,其具体结构为:浏览器构的一种实现方式,其具体结构为:浏览器/Web服务器服务器/数据库服务器。数

16、据库服务器。35浏览器浏览器/ /服务器风格服务器风格 B/S体系结构主要是利用不断成熟的体系结构主要是利用不断成熟的WWW浏览浏览器技术,结合浏览器的多种脚本语言,用通用浏器技术,结合浏览器的多种脚本语言,用通用浏览器就实现了原来需要复杂的专用软件才能实现览器就实现了原来需要复杂的专用软件才能实现的强大功能,并节约了开发成本。的强大功能,并节约了开发成本。 从某种程度上来说,从某种程度上来说,B/S结构是一种全新的软件结构是一种全新的软件体系结构。体系结构。36浏览器浏览器/ /服务器风格的体系结构服务器风格的体系结构数据库服务器数据库客户端浏览器客户端浏览器Web服务器37浏览器浏览器/

17、/服务器风格的优点服务器风格的优点 基于基于B/S体系结构的软件,系统安装、修改体系结构的软件,系统安装、修改和维护全在服务器端解决。和维护全在服务器端解决。 用户在使用系统时,仅仅需要一个浏览器用户在使用系统时,仅仅需要一个浏览器就可运行全部的模块,真正达到了就可运行全部的模块,真正达到了“零客零客户端户端”的功能,很容易在运行时自动升级。的功能,很容易在运行时自动升级。38浏览器浏览器/ /服务器风格的优点服务器风格的优点 B/S体系结构还提供了异种机、异种网、异体系结构还提供了异种机、异种网、异种应用服务的联机、联网、统一服务的最种应用服务的联机、联网、统一服务的最现实的开放性基础。现实

18、的开放性基础。39浏览器浏览器/ /服务器风格的缺点服务器风格的缺点 B/S体系结构缺乏对动态页面的支持能力,体系结构缺乏对动态页面的支持能力,没有集成有效的数据库处理功能。没有集成有效的数据库处理功能。 B/S体系结构的系统扩展能力差,安全性难体系结构的系统扩展能力差,安全性难以控制。以控制。40浏览器浏览器/ /服务器风格的缺点服务器风格的缺点 采用采用B/S体系结构的应用系统,在数据查询等响体系结构的应用系统,在数据查询等响应速度上,要远远地低于应速度上,要远远地低于C/S体系结构。体系结构。 B/S体系结构的数据提交一般以页面为单位,数体系结构的数据提交一般以页面为单位,数据的动态交互

19、性不强,不利于在线事务处理据的动态交互性不强,不利于在线事务处理(OLTP)应用。应用。 OLTP是在线事务处理。比如收银台就像是是在线事务处理。比如收银台就像是OLTP,因为不断有数据的录入(或是修改);因为不断有数据的录入(或是修改); OLTP就是数据库数据一直在变动、更新的就是数据库数据一直在变动、更新的41第三章第三章 软件体系结构风格软件体系结构风格公共对象请求代理结构公共对象请求代理结构42对象管理结构对象管理结构 公共对象请求代理结构公共对象请求代理结构CORBA(Common Object Request Broker Architecture)是一种独立于语言和软件)是一种

20、独立于语言和软件/硬件平台的软件构件模型。硬件平台的软件构件模型。43CORBA的构成的构成 CORBA主要由对象请求代理、公共对象服主要由对象请求代理、公共对象服务、通用设施和应用接口组成。务、通用设施和应用接口组成。44对象请求代理对象请求代理ORB 请求代理是建立基于分布式对象的应用程序的基础,使请求代理是建立基于分布式对象的应用程序的基础,使得分布式对象之间能够透明的发送请求或接受响应得分布式对象之间能够透明的发送请求或接受响应 在在CORBA中,所有的通信都通过中,所有的通信都通过ORB进行,因而无论进行,因而无论一个对象是本地的还是远程的,对于与之进行通信的其一个对象是本地的还是远

21、程的,对于与之进行通信的其他对象来说都是等价的他对象来说都是等价的 CORBA保证了异构和同构环境中对象的可移植性和可保证了异构和同构环境中对象的可移植性和可互操作性互操作性 ORB独立于实现对象的特定平台与技术,客户程序无独立于实现对象的特定平台与技术,客户程序无需知道如何与对象通信、如何激活对象、对象如何实现、需知道如何与对象通信、如何激活对象、对象如何实现、如何查找对象如何查找对象45对象请求代理对象请求代理ORB 请求代理是建立基于分布式对象的应用程序的基础,使请求代理是建立基于分布式对象的应用程序的基础,使得分布式对象之间能够透明的发送请求或接受响应得分布式对象之间能够透明的发送请求

22、或接受响应 对象请求代理对象请求代理ORB规定了分布对象的接口定义和语言规定了分布对象的接口定义和语言映射、实现了对象间的透明通信和互操作,是分布对象映射、实现了对象间的透明通信和互操作,是分布对象的的“软总线软总线” 在在ORB上定义了并发服务、命名服务、时间服务、安上定义了并发服务、命名服务、时间服务、安全服务等多样公共服务;全服务等多样公共服务; 通用设施定义了构件框架,为领域对象提供可使用的共通用设施定义了构件框架,为领域对象提供可使用的共享服务,规定领域对象有效协作所需的规则。享服务,规定领域对象有效协作所需的规则。46CORBA对象服务 对象服务是对象管理体系结构对象服务是对象管理

23、体系结构OMA定义的一系定义的一系列独立于应用领域的服务列独立于应用领域的服务 CORBA服务是开发分布式应用所必需的模块,服务是开发分布式应用所必需的模块,用来提供基本用来提供基本ORB功能之上的更高系统级服务。功能之上的更高系统级服务。主要处理核心系统级功能,如异步事件管理、持主要处理核心系统级功能,如异步事件管理、持久性和事务、安全性、并发、命名、消息接发以久性和事务、安全性、并发、命名、消息接发以及目录服务,这些服务要么是基于及目录服务,这些服务要么是基于CORBA的应的应用程序的基础,要么用于为应用程序提供可互操用程序的基础,要么用于为应用程序提供可互操作性,形成了构件高级工具和业务

24、功能的框架作性,形成了构件高级工具和业务功能的框架47CORBA对象服务 对象服务的本职是将覆盖对象整个生存期的对象对象服务的本职是将覆盖对象整个生存期的对象管理任务标准化,例如对象服务提供的功能包括管理任务标准化,例如对象服务提供的功能包括了创建对象、对象访问控制、查找对象、维持对了创建对象、对象访问控制、查找对象、维持对象间关系等象间关系等 这种标准化可导致不同应用程序的一致性,并提这种标准化可导致不同应用程序的一致性,并提高软件开发者的生产率高软件开发者的生产率48CORBA对象服务 对象服务规范包含在对象服务规范包含在CORBA服务的公共服务规服务的公共服务规范中,服务规范主要处理各种

25、服务,并定义范中,服务规范主要处理各种服务,并定义IDL接口,以及非形式化的描述这些接口的语义接口,以及非形式化的描述这些接口的语义 这些服务独立于应用领域,包括:命名服务、事这些服务独立于应用领域,包括:命名服务、事件服务、持久对象、并发控制、外表化、许可机件服务、持久对象、并发控制、外表化、许可机制、查询、属性、安全性、时间、对象收集、交制、查询、属性、安全性、时间、对象收集、交易服务等服务的规范易服务等服务的规范49CORBA通用设施 通用设施(通用设施(Common Facilities)是)是IDL定义的、定义的、向终端用户应用程序提供的一组服务接口的集合。向终端用户应用程序提供的一

26、组服务接口的集合。 通用设施可用于大多数应用领域,包括分布式文通用设施可用于大多数应用领域,包括分布式文档设施、打印设施、数据库设施、电子邮件设施档设施、打印设施、数据库设施、电子邮件设施等。等。50CORBA应用程序接口 应用程序对象位于整个应用程序对象位于整个OMA参考模型的最高层。参考模型的最高层。它们不是由它们不是由OMG来标准化的,而是符合传统上来标准化的,而是符合传统上对应用程序的认识。对应用程序的认识。 应用程序对象为终端用户执行特定的任务,主要应用程序对象为终端用户执行特定的任务,主要为某一类应用或一个特定的应用提供服务为某一类应用或一个特定的应用提供服务51对象管理结构对象管

27、理结构52CORBA的特点 CORBA在基于网络的分布式应用环境下实现应用软件的集成。 CORBA采用并吸收了面向对象技术、分布式计算技术和多层体系结构技术,实现了在分布式应用环境中软件的可复用性、可移植性和互操作性。53CORBA的特点 提供“软件总线”机制 “软件总线”机制简化了分布式应用系统的复杂性。 任何应用只要提供按照CORBA规范定义的一组接口,就可以方便的集成到CORBA系统中。接口规范独立于任何实现语言和环境。因此,客户应用和服务对象之间可以透明的交互运行,实现应用程序在“软件总线”上的即插即用。54CORBA的特点 使用代理扩展了客户/服务器的计算模型 代理的作用是:完成对客

28、户发出的抽象服务请求的映射,自动发现并找到服务器,自动设定路由,实现服务器程序的执行 客户和服务器完全分离。这和传统的客户/服务器方式有很大的不同客户不再与服务器直接联系,而是与代理发生联系。这样,客户和服务器都易于维护、修改55CORBA的特点 使用IDL定义接口 通过从IDL到具体编程语言映射的方式,CORBA对象可以用任何一种CORBA软件开发商所支持的语言,如C,C+,Java,Ada和Smalltalk等56CORBA的特点 引入中间件作为事务代理,用于传递客户提出的服务请求及得到的服务结果。 实现客户程序与对象实现之间的完全分离,客户端程序不需要了解对象的具体实现、操作平台和位置信

29、息。 提供“软总线”功能,对于任何环境、任何程序设计语言,只要遵循接口规范,就可以集成到已有的分布式系统中来。57CORBA的特点 采用接口技术,使得软件总体设计、详细设计、代码编写以及维护等方面可以独立进行,同时又可以保证代码的一致性。 采用面向对象技术,使得在软件开发中能很好的实现信息封装、代码复用。58基于Java平台的分布式计算 Sun公司于1995年正式推出Java技术。由于Java在网络计算领域中的跨平台优势,Java已从一种编程语言逐渐发展成一个软件开发平台,被计算机业界广泛接受,并被越来越多的标准化组织采纳为国际标准或行业标准 Sun于1996年发布了JDK1.0,1997年发

30、布了JDK1.1,1998年发布了JDK1.2(Java 2),2000年JDK1.3,目前是JDK1.659基于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 Enviro

31、nment)是Sun公司2001年发布的,用于实现异构网络环境下的分布式计算的软件体系结构,用用于实现Web Service的平台60Java RMI 在进行本地或远程机器上的进程间通信、远程执行代码时,有多种技术可用。最早且最常用的方法是在进程之间建立通信链路。 通过这条链路,一个进程可以把某些操作和数据按照约定的格式发送给另一个进程 接收进程在解码后,执行响应的操作,并用同样的方法将结果返回给发起进程 套接字编程就采用了这种方法61Java RMI 但是,采用这种方法时,程序员必须给每个应用程序创建一个表示操作和数据的编码方式。 这种做法还将引入两种不同的典型编程方法 程序设计语言的过程调

32、用/参数传递模型 用于套接字的编程的命令模型 加大了开发难度 远程机器之间的数据格式和字节排序顺序都可能不同,这种数据格式的平台相关性增大了通信的复杂性62Java RMI 另一种方法是远程过程调用(Remote Procedure Call) 使用这种方法,远程进程间的通信和调用能够以一种类似于本地过程调用和参数传递那样的方式进行,这使得程序设计中能使用统一的编程风格。 但是数据格式和字节排列顺序的问题仍然存在,而且RPC是一种面向处理的程序风格,不适用于面向对象的系统设计方案63Java RMI Java 远程方法调用,Java RMI(Java Remote Method Invocat

33、ion)是以同构的Java虚拟机环境为基础的一种解决方案 Java RMI利用Java对象模型的优点,是一种纯Java的分布式应用核心解决方案64Java语言支持分布式对象的目标 在保留大部分Java语言对象语义的同时,用较为自然的方式将分布式对象模型集成到Java语言中 在不同的虚拟机上支持对象的无缝远程调用 支持从服务器到applet的回调 使分布式对象模型和本地Java对象模型的差异明朗化 为远程对象提供各种引用语义,例如非持久引用、持久引用和惰性激活 实现安全管理器和类加载器提供的安全可靠的Java环境65Java RMI概述 RMI是JSDK的一部分,是一个支持分布式计算应用程序的远

34、程方法调用和返回的API 在RMI中,任何一个可以被其他Java虚拟机调用其方法的对象称为远程对象(Remote Object)。 远程对象是网络对象,调用它们的客户或其他远程对象的地理位置是透明的。 既可能是位于同一个地址空间内,也可能是跨越互联网的调用 RMI在处理本地调用和分布式对象的方法调用时,使用几乎相同的编程模型,并假设调用方法和被调用方法均使用Java语言66Java RMI的编组和解组 RMI允许通过网络传递参数,包括Java基本元和对象 编组和解组是使参数在被请求机器上可以使用的处理方法,它将参数打包、拆包,从而使得它们可应用于不同的环境67Java RMI参数传递 RMI允

35、许两种方法传递参数:值传递和引用传递 值传递时,在远程主机上的另一个进程创建新对象,并将参数复制到新对象中。 引用传递时,远程主机收到的是原对象的一个引用,而不是具体拷贝。所以它不在另一个进程中创建对象,对象仍留在原地,并进行远程操作。这些远程操作所做出的修改会影响原始数据68Java RMI远程对象和远程接口 RMI就是调用远程对象上远程接口的方法的动作。远程对象由一种或多种远程接口描述。 客户可以向位于另一台机器的远程对象发送一条消息,并获得返回结果,就像那些对象位于本地机器一样。远程对象的方法调用与本地对象的方法调用语法相同69Java RMI安全性 RMI使用Java内置的安全机制保证

36、下载执行的程序时用户系统的安全 RMI使用专门为保护系统免遭恶意Java Applet侵害而设计的安全管理程序,可保护系统和网络免遭潜在的恶意下载程序的破坏。 在情况严重时,服务器可拒绝下载任何执行程序70Java RMI兼容性 RMI可通过Java的本机方法接口JNI与现有系统进行交互。 利用RMI和JNI,就能用Java编写客户端程序,还能使用现有的服务器端程序。 使用RMI/JNI与现有服务器连接时,可以有选择的用Java重新编写服务程序的任何部分,并使新的程序充分发挥Java功能。 RMI可以利用JDBC,在不修改使用数据库的现有非Java源代码的前提下与现有数据库进行交互71Java

37、 RMI分布式垃圾收集72Java RMI73Java RMI74Java RMI75Java RMI76Java RMI77Java RMI78基于Java平台的分布式计算79第三章第三章 软件体系结构风格软件体系结构风格正交软件体系结构正交软件体系结构80正交软件体系结构的概念 正交软件体系结构由组织层和线索的构件构成。正交软件体系结构由组织层和线索的构件构成。 层是由一组具有相同抽象级别的构件构成。层是由一组具有相同抽象级别的构件构成。 线索是子系统的特例,它是由完成不同层次功能线索是子系统的特例,它是由完成不同层次功能的构件组成(通过相互调用来关联),每一条线的构件组成(通过相互调用来

38、关联),每一条线索完成整个系统中相对独立的一部分功能。索完成整个系统中相对独立的一部分功能。81正交软件体系结构的线索 每一条线索的实现与其他线索的实现无关或关联每一条线索的实现与其他线索的实现无关或关联很少,在同一层中的构件之间是不存在相互调用很少,在同一层中的构件之间是不存在相互调用的。的。 如果线索是相互独立的,即不同线索中的构件之如果线索是相互独立的,即不同线索中的构件之间没有相互调用,那么这个结构就是完全正交的。间没有相互调用,那么这个结构就是完全正交的。 82正交软件体系结构的框架框架ACBDGFHEJK第一层第二层第五层第四层第三层83 大型和复杂的软件系统,其子线索可以划分为更

39、低一级的子线索,形成多级正交结构 同一层次的构件不允许互相调用84系统演化对体系结构的影响 在系统演化过程中,系统需求不断发生变化。 在正交软件体系结构中,因线索的正交性,每个需求的变动仅影响某一条线索,不会影响其他线索。这样,把软件需求的变动局部化了,产生的影响也被限制在一定的范围内,容易实现85系统演化对体系结构的影响 多级正交结构对于降低软件演化更新的开销是行之有效的 适合大型软件开发,特别是MIS领域86正交软件体系结构的特征特征 正交软件体系结构由完成不同功能的正交软件体系结构由完成不同功能的n(n 1)个线索(子系统)组成;)个线索(子系统)组成; 系统具有系统具有m(m 1)个不

40、同抽象级别的层;)个不同抽象级别的层; 线索之间是相互独立的(正交的);线索之间是相互独立的(正交的); 系统有一个公共驱动层(一般为最高层)和系统有一个公共驱动层(一般为最高层)和公共数据结构(一般为最低层)。公共数据结构(一般为最低层)。 87正交软件体系结构的特点 结构清晰,易于理解。结构清晰,易于理解。 由于线索功能相互独立,不进行互相调用,结由于线索功能相互独立,不进行互相调用,结构简单、清晰,构件在结构图中的位置已经说构简单、清晰,构件在结构图中的位置已经说明它所实现的是哪一级抽象,担负的是什么功明它所实现的是哪一级抽象,担负的是什么功能。能。88正交软件体系结构的特点 易修改,可维护性强。易修改,可维护性强。 由于线索之间是相互独立的,所以对一个线索由于线索之间是相互独立的,所以对一个线索的修改不会影响到其他线索。的修改不会影响到其他线索。 系统功能的增加或减少,只需相应的增删线索系统功能的增加或减少,只需相应的增删线索构件族,而不影响整个正交体系结构,因此能构件族,而不影响整个正交体系结构,因此能方便地实现结构调整。方便地实现结构调整。89正交软件体系结构的特点 可移植性强,重用粒度大。可移植性强,重用粒度大。 因为正交结构可以为一个领域内的所有应用程因为正交结构可以

温馨提示

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

评论

0/150

提交评论