查看完整版本: 基于多代理的网格服务模型的研究与应用

admin 发表于 2014-10-13 12:22:56

基于多代理的网格服务模型的研究与应用

开放网格服务体系结构(OGSA)的出现使得原来的网格资源管理模式不能够满足要求,本文引入代理技术,详细地介绍了多代理技术,代理交互等概念,改善了OGSA模型中Web服务层,将多代理技术应用于网格服务体系结构,根据堆优先权算法,设计出多过程算法提高了服务效率,并设计出基于多代理的公安局网格服务管理模型系统。

1 引言

随着网络速度的成倍增长,各种计算资 源的能力越来越强大,这使得一种新的网格 计算模式——网格计算的出现成为可能。网 格计算是指在动态的、异构的、广域的虚拟 组织中进行的协同资源共享和问题求解 。 在分布式系统中,软件代理起着越来越 重要的作用。

它在提高效率和性能方面 有很大的优势。代理是一个自治的过程,它 具有反馈,适应环境变化,与用户协作,与 其它代理交互的特点。这些特点被用于实现 资源管理,工作流管理和性能优化。

本文首先介绍了网格的基本概念,然后 引出了多代理的相关知识,在此基础上,结 合网格框架,将多代理技术应用于公安局网 格服务模型。

2 网格技术

网格是把整个因特网整合成一台巨大 的超级计算机,实现各种资源的全面共享。 当然,网格并不一定非要这么大,也可以构 造地区性的网格,如企事业内部网格、局域 网网格,甚至家庭网格和个人网格等等。网 格的本质特征是:分布于资源共享。分布是 网格最本源的特征,网格是通过集中分散的 资源完成计算的,资源共享是一种集中资源 高度抽象。网格的特点:分布性,共享性, 自相似性,动态性,异构性,多级自治管理 域等等。

随着网格的发展,现在主要有两个网格 体系结构标准:一个是面向协议的五层沙漏 结构,另一个是面向服务的开放式网格服务 体系结构(Open Grid Service Architecture) 。

如图1 显示了OGSA 的基本框架。OGSA 是在原来“五层沙漏结构” 的基础上,结合最新的Web Service 技术 提出来的,它解决了两个重要的问题,即标 准服务接口的定义和协议的识别。OGSA 包 括两大关键技术,即网格技术和Web Service 技术。



以服务为中心是OGSA 的基 本思想,在 OGSA 中一切都是服务,包括计 算机、程序、数据、仪器设备等。这种观念, 有利于通过统一的标准接口来管理和使用 网格。这一结构的意义,就在于它将网格从 以科学和工程计算为中心的学术研究领域, 扩展到更广泛的以分布式系统服务集成为 主要特征的社会经济活动领域。

3 多代理技术

代理技术广泛地用于人工智能领 域。它能运行于一台计算机或一类同性质的 系统中。具有自治,自适应,交互,互操作 等特点。这些特点可以保证网格服务的性 能。特别是服务发现机制能提高性能。本文 所述的代理的技术主要应用于OGSA 的第三 层,即Web服务层。

3.1多代理层次模型

多代理层次模型如图2 所示。这个模型 主要是用来改进开放式网格服务系统的性 能的.在所提出的结构中,网格服务功能是 由代理所表现出来的。




一般的,像自适应性 和互操作性等特点与网格服务相结合来提 高网格服务功能。网格中基于代理部署的优 点是服务性能将会由网格学习和交互所改善。 代理服务管理器(ASM)是一个重要的部 件,它管理着大规模同类分布式环境,同时 它也管理所有的代理。ASM 所起的作用是监 视、调度和提供代理管理机制,同时,ASM 也与用户相交互。除此之外,监视模块被提 供用来从代理接收数据和管理代理系统。

代理是基于层次模型。层次模型被用于 解决可测量性问题。大规模复杂的软件系统 大都采用软件代理。在图2中,代理有相同 的组件模型。

当然,每个代理都有一组相同 的功能集合。发送请求和提供服务是网格服 务系统中所有代理的特点。所采用的模型主 要的目的是满足可测量性的要求,可测量要 求是网格计算中的一个关键的因素。除此之 外,层次模型也用于代理之间的交流和服务 发现。

3.2代理交互

代理的交互是基于面向服务的模型。根 据前面所述,层次模型用来提供目录,这些 目录是用于代理发布他们的功能和寻找请 求所需功能的代理。除了这些功能之外,代 理之间是基于访问控制表(ACL)来传递 消息的。

代理之间的通信如图3 所示,代理是通 过ACL 来交互的。在模型中,ACL 是由XML 协议所映射的。XML 的内容将会被送到 SOAP(Simple Object Access Protocol),这是用来XML 编码用来交换信息。



一个代理 将会被看作是Web服务用来为每一种性能提 供一种方法。在提出的交互模型中,代理者 被代理所请求用来找到其他的位置,它也被 用来固定代理层次。当一个父亲与孩子节点 的连接破坏是,代理者将会用它的含有表示 符合代理位置的表格来重建层次模型。

4 多代理技术在网格中的应用

4.1概述

公安局网格管理系统就是利用网格的 各种技术将各部门的资源结合在一起,实现 快速、有效、方便的查询和管理各类资源。 因此根据前面对网格及多代理机制的描述, 将多代理技术应用于网格服务模型,并设计 出公安局网格服务模型,该模型框架如图4 所示:



基于多代理的公安局网格模型应具有 如下功能:

1、提供用户安全认证服务。

2、服务质量保证。

3、代理之间能够协作可以共同完成任务。

4、代理服务管理管理代理。

基于多代理的公安局网格模型的工作 过程如下:

(1)网格用户通过用户身份认证进入网 格管理系统。

(2)网格用户通过网格应用程序提交网 格应用请求。

(3)代理服务管理接收到用户的请求后, 将任务分配各个代理处理。

(4)代理在进行任务处理时,同时可以 与代理服务管理进行交互,而且代理之间可 以协作共同完成某项任务。

(5)代理在完成代理服务管理分发的任 务后,将结果交还给代理服务管理,由它向 上层用户提交结果。 在基于多代理的公安局服务模型中,对 用户的请求进行了分类,每一类任务由一种 代理独立完成或多个代理协作完成,这恰恰 体现了代理的互操作性。


另外,假设用户对 所需的服务可能不止一次,当相同的服务再 次需要时,代理就会很快地找到所需的服 务,这满足了代理自治性的特点。除了以上 两点之外,模型还有如下优点:

1、平台无 关性。服务资源通过网格服务的虚拟化实现 平台无关,不同类型的服务资源被封装能够 提供不同服务,服务的描述与所提供服务的 具体设备和操作系统无关。

2、服务质量保 证。在所提出的模型中,我们利用堆优先权 算法,设计出多过程算法来保证服务质 量(伪代码,语言是C++):

Vector InQueue,ProcessQueue;

If(InQueue==NULL)

Wait(data);

Else

{

if(SearchMax(Priority,ProcessQueue))

{

Find(agent);

Send(data,Priority,agent);

EQueue(agent,ProcessQueue);

}

Translate(data);

Store(Sendagent,Receiveagent,

ProcessQueue);

说明如下:InQueue,ProcessQueue是接 收队列和处理队列,Priority 是代理的优先 权,data 是数据。工作原理说明如下:首先 监视模块查询接收队列,如果为空就等待数 据,否则从处理队列中选取优先权(采用堆 优先权算法)最大的代理,把数据,优先权 保存到处理队列中,然后传送数据,保存发 送代理和接收代理到处理队列。 模型在多代理技术的基础之上,提出了 在代理服务管理模块上提供了一个接口,通 过这个接口可以访问更高一级的公安局的 资源,从而更加有效的实现了资源共享。

系统同时体现网格的优点:1、分布性。 各个公安局分布在不同的地方,具有分布 性。2、异构性。组成系统的操作系统有Unix,也有Linux和Windows,操作系统是异构的; 数据库有Oracle 也有SQL 或其他,数据库 也是异构的。3、用户透明。对于用户来说, 只需要提交相应的服务请求,便会得到相应 的服务,不需要知道服务的提供者,系统对 用户是透明的。

5 结束语

本文先叙述了网格的相关术语,然后引 进了多代理的技术,将多代理技术应用于开 放网格模型中的Web服务层,设计出基于多 代理的网格服务模型,并描述了模型的工作 原理以及模型的优点。

创新观点:把代理技术运用于网格中,利用 堆优先权算法,设计出多过程算法保证服务 质量,并应用于一个实际的项目中
页: [1]
查看完整版本: 基于多代理的网格服务模型的研究与应用