常见分布式计算技术

中间件技术

中间件作为构建,是分布式系统中介于应用层和网络层的一个功能层次,它能够屏蔽操作系统(或网络协议)的差异,实现分布式异构系统之间的互通或互操作。分布式 应用软件借助这种软件在不同的域之间共享资源。中间件位于客户机服务器的操作系统之上,管理计算资源和网络通信。它扩展了C/S结构,形成了一个包括客 户端、中间件和服务器的多层结构。

基于中间件的分布式计算技术以中间件为桥梁,通过把数据转移到计算之处的计算方式,把网络系统的所有组件集成为一个连贯的可操作的异构系统,从而达到网络“透明”的目的。

早期的中间件比较简单,仅具有消息通讯和事务管理功能。但随着需求的多样化,也产生了许多不同类别的中间件产品,如:消息中间件(MOM :Message-Oriented Middleware)、数据库中间件(Database Middleware)、远程过程调用中间件(RPC :Remote Process Call)、对象请求代理中间件(ORB :Object Request Broker)和事务处理中间件(TP Monitor:Transaction Process Monitor)。

网格技术

网格计算是通过Internet把分散在各处的硬件、软件、信息资源连结成为一个巨大的整体,从而使得人们能够利用地理上分散于各处的资源,完成各种大规 模的、复杂的计算和数据处理的任务。网格计算建立的是一种新型的Internet基础支撑结构,目标是将与Internet互联的计算机设施社会化。网格计算的发展非常迅速,数据网格、服务网格、计算网格等各种网格系统在全球范围内得到广泛的研究和实施。网格计算无疑是分布式计算技术通向计算时代的一个非常重要的里程碑。

网格的体系结构是有效进行网格计算的重要基础,到目前为止比较重要的网格体系结构有两个: 一个是以Globus项目为代表的五层沙漏结构,它是一个以协议为中心的框架;另一个是与Web服务相融合的开放网格服务结构OGSA(Open Grid Services Architecture),它与Web 服务一样都是以服务为中心。但是,所有的网格系统都有这样一个基本的、公共的体系结构:资源层、中间件层和应用层。

(1)网格资源层:它是构成网格系统的硬件基础。包括Internet各种计算资源,这些计算资源通过网络设备连接起来。

(2)网格中间件层:它是一系列工具和协议软件。其功能是屏蔽资源层中计算资源的分布、异构特性,向网格应用层提供透明、一致的使用接口。

(3)网格应用层:它是用户需求的具体体现。在网格操作系统的支持下,提供系统能接受的语言、Web 服务接口、二次开发环境和工具,并可配置支持工程应用、数据库访问的软件等。

移动Agent技术

目前还没有一个关于移动Agent的确切定义,我们一般认为移动Agent是一类能在自己控制之下从一台计算机移动到另一台计算机的自治程序,它们能为分布式应用提供方便的、高效的执行框架。

移动Agent是一类特殊的软件Agent,可以看成是软件Agent技术与分布式计算技术相结合的产物,它除了具有软件Agent的基本特性 ——自治性、响应性、主动性和推理性外,还具有移动性,即它可以在网络上从一台主机自主地移动到另一台主机,代表用户完成指定的任务。由于移动Agent 可以在异构的软、硬件网络环境中自由移动,因此这种新的计算模式能有效地降低分布式计算中的网络负载、提高通信效率、动态适应变化的网络环境,并具有很好 的安全性和容错能力。但目前,所有的移动Agent系统还都很不成熟,存在着各种各样的缺陷。所以,我们可以把目前的众多Agent系统看成是实验室系 统,它们离真正实用的产品还有很大的距离。

P2P技术

P2P 系统由若干互联协作的计算机构成,是Internet上实施分布式计算的新模式。它把C/S与B/S系统中的角色一体化,引导网络计算模式从集中式向分布 式偏移,也就是说网络应用的核心从中央服务器向网络边缘的终端设备扩散,通过服务器与服务器、服务器与PC机、PC机与PC机、PC机与WAP手机等两者 之间的直接交换而达成计算机资源与信息共享。

此外一个P2P系统至少应具有如下特征之一:第一、系统依存于边缘化(非中央式服务器)设备的主动协作,每个成员直接从其他成员而不是从服务器的参与中受 益;第二、系统中成员同时扮演服务器与客户端的角色;第三、系统应用的用户能够意识到彼此的存在,构成一个虚拟或实际的群体。P2P技术已发展为一种重要 的分布式计算技术,典型代表就是Napster。

Web Service技术

Web Service技术是对对传统Web应用的功能性方面的一种延伸和辐射,为不同系统或者是系统和终端之间提供服务。Web Service结合了以组件为基础的开发模式以及Web的出色性能,一方面,Web Service和组件一样,具有黑匣子的功能,可以在不关心功能如何实现的情况下重用;同时,与传统的组件技术不同,Web Service可以把不同平台开发的不同类型的功能块集成在一起,提供相互之间的互操作。

我们也可以认为Web Service技术是以Internet为载体,通过将紧密连接的、高效的n层计算技术与面向消息、松散联接的Web概念相结合来实现的。Web服务是一种构建在简单对象访问协议(SOAP)之上的分布式应用程序,其实质是由XML通过HTTP 协议来调度的远过程调用。

我们说Web Service技术是新一代的分布式计算和处理技术,主要是因为它在Internet 上表现出来的高度扩展性。原有的中间件平台技术都是基于C/S体系结构,这要求两端必须是同质的而且是紧密联接的基础体系,如果任何一端接口发生变化,另 一端的程序必然会中断。这种模型扩展性是较差的,特别是无法扩展到Internet ,这是受限于计算机操作系统、对象模型和编程语言的差异性;而Web Service技术是跨平台的,联接非常松散,采用的是性能稳定的、基于消息的异步技术,在改变任何一端接口的情况下,应用程序仍可以不受影响地工作。它为集成分布式应用中的中间件及其它组件提供了一个公共的框架,无须再考虑每一个组件的具体实现方式。

总结

现在用得最多的分布式技术应该是中间件技术和web service技术,或者是2者技术的结合。同时,这两者的结合也是实现SOA的具体方式。

你可能感兴趣的:(常见分布式计算技术)