网格协同设计环境中的任务调度机制_第1页
网格协同设计环境中的任务调度机制_第2页
网格协同设计环境中的任务调度机制_第3页
网格协同设计环境中的任务调度机制_第4页
全文预览已结束

下载本文档

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

文档简介

1、网格协同设计环境中的任务调度机制杨格兰,左伟明 时间:2008年05月06日 字 体: 大 中 小关键词:摘要:关键词: 网格 协同设计 任务调度 资源预留协同设计(Collaborative Design)是指在计算机的支持下,各成员围绕一个设计对象,各自承担相应部分的设计任务,并行交互地进行设计工作,最终得到符合要求的设计结果的设计1。网格的出现为协同设计带来了崭新的解决思路。借助于网格研究的基础设施以及Globus联盟推出的网格既定标准GT3(Globus Toolkit 3),可以为制造业网络设计提供极为方便的底层支撑,为快速建立一个健壮的设计平台提供保证,GMCD4就是这样一个设计平

2、台。本文将首先分析网格环境中任务调度的模型,然后基于协同设计环境的特殊性,以GMCD为框架,建立一种实用的任务调度模型。1 网格任务调度模型1.1 网格任务调度的相关组件及功能3:(1)资源请求代理它是整个网格的资源管理者,负责接收用户任务,根据其特点发送给域资源管理器,动态监视任务的运行情况,根据需要将结果提交给用户或进行再调度。主要功能有:对服务提供方提供注册功能,并对其加入和退出等动作进行控制。建立网格资源信息库并周期性地刷新,对全局资源进行统一管理和分配。接收用户提交的作业,并根据作业类型和要求(如资源的类型和数量等)形成作业调度参数。根据作业调度参数调度作业,分派资源,并随时监视作业

3、的执行情况。若作业执行有误,则对其进行再调度,保证用户作业的安全运行。(2)域资源管理器它是域内资源管理和动态调度的中心,负责本域工作的创建、属性的收集、接收从资源请求代理提交的任务并根据其特点进行处理机的分配。主要功能有:监听从本域结点发送来的信息,建立域成员信息资料库并周期性刷新。周期性地接收由资源请求代理提交的作业,并判断其可行性,建立本域的任务队列。从任务队列中选取作业,根据提交的参数和资源情况合理地分配作业。将作业执行情况定时返回给资源请求代理,维持与上级数据库的一致性。监视各组员执行状况,根据情况进行作业调整(域内调整或再调度)。确保用户作业的安全运行,将结果通知资源请求代理并直接

4、返还给用户。(3)网格工作结点它是任务执行的基本单位,一旦申请加入资源提供方,便由域资源管理器直接调度和由资源请求代理间接调度。主要功能有:向上级管理器提出申请,请求加入资源提供方。收集本结点的状态和负载信息,并周期性地提交给域资源管理器。产生服务进程,随时接收上级管理器提交的任务并执行。(4)负责联系的组件鉴于各实体间的联系比较多,可将其分为作业提交和资源汇报两部分。作业提交部分用户向资源请求代理提交作业任务;资源请求代理根据用户参数将作业转交给域资源管理器;域资源管理器根据各结点负载情况分派作业给合适的资源工作结点,任务执行完毕后保存作业结果;域资源管理器直接将结果返回给用户。资源汇报部分

5、它完成如下任务:网格工作结点向域资源管理器提供各结点的状态和负载情况;域资源管理器将该域的负载信息汇总并送给资源请求代理供查询和管理结点;域资源管理器周期性地刷新资源请求代理中的作业状态;工作结点执行完毕。1.2 网格任务调度的过程用户利用提交程序将作业任务和要求的环境属性(如资源类型和数量等)提交给资源请求代理,资源请求代理分析环境属性形成参数文件,根据任务性质、通信状况和各资源负载情况进行粗粒度调度,寻求最佳分配方案将作业及参数文件提交给选中的域资源管理器。当域资源管理器接收到新任务或调度周期到来时,新任务被赋予任务优先级插入作业队列。守护进程从结点机列表中获取该域内所有资源负载情况,同时

6、更新资源请求代理上全局数据库中相关的信息表。确定已经到达该域的任务的优先级,每次选取一个任务分配合适的资源。相应地,守护进程派生出相应的作业线程,周期性地监视该作业的执行状态,并向上一级(资源请求代理)汇报, 以便进行全局管理与调度(或用户查询)。当任务途中异常中断或执行性能比预期要差时,资源请求代理可进行再次调度,重新安排其他资源;而当任务完成时,资源请求代理会要求域资源管理器直接将作业结果返还给用户。2 GMCD中的任务调度机制4、网格中间件、设计中间件和应用层,如图1所示。DKU及互联网络组成了GMCD的底层支持结构。DKU是Internet上的具有设计能力的组织或机构,它们在某一类产品

7、或零部件研发上具有先进的设计技术和生产能力。在DKU内部存在设计知识数据库、局域网和设计工具(集)。它们之间通过Internet或专用高速网连通。在设计过程中,各个DKU之间具有平等关系,各自负责所获得任务的运行,相对来说是独立的。用户在应用层通过Portal将任务提交给设计中间件。设计中间件将由Portal提交的设计任务分解为可以被DKU执行的子任务。分解过程如下。GMCD任务分解分为两层。任务以XML(eXtensible Markup Language)文件形式被提交后,首先会由资源请求代理转交给自称能完成该任务的域,然后在域控制管理器内被首次分解,分解的原则是可执行原则。对于已经进入域

8、控制管理器的任务,应用分解智能体根据知识库内的知识,将其分解为可以被DKU执行的任务。知识库内保留了该域内所有DKU的功能申明。域内任务分解(高层分解)的目标是把任务分解为可以被DKU执行的子任务,低层任务分解在DKU内进行,其目标是把子任务分解为可以被DKU中服务器执行的底层操作。由于设计工作的特殊性,DKU分布通常不均匀,能完成有关联或相似性设计任务的DKU通常在一个或几个域内。如果被提交的设计任务没有合适的域可以执行,则还要在高层分解之前加入一层手工分解或由资源请求代理分解。也就是说,可以把任务返还给用户,由用户根据一定的设计知识对设计任务实行手工分解,也可以由资源请求代理根据域的功能自

9、述分解为可以被域执行的子任务。域资源管理器和DKU的关系如图2所示。子任务在DKU内被重新解析为可以被服务器执行的底层任务,然后由DKU调度到各个服务器上去执行。高层分解和低层分解在失败时都回溯。分解后的任务由域调度器调度到合适的DKU上去执行。GMCD的任务映射分为三个层次。资源请求代理保留了每个域的功能自述副本。任务通过Portal提交后,根据域的功能自述,被转交给能完成该任务的域;然后在域内分解再由域调度器进行二次映射,二次调度的目的是把分解后的子任务映射到合适的DKU上去;在DKU内的调度是第三次映射,这次调度的目的是把解析子任务后得到的底层任务映射到合适的服务器上去。本文所关注的是第

10、二次调度,也就是分解以后的任务如何由域调度器调度到DKU上。在第二次调度中,由于设计任务的特殊性,一组相似或相关任务通常会在一个时间段内陆续到达。3 资源预留的引入资源预留是网格系统中一个十分必要的机制,因为资源预留可以保证任务在开始执行时获得必要的资源,从而提高网格系统的QoS。因此,资源预留的提出,从一开始就得到了广泛的认可,在目前网格系统的调度模块中已经被广泛采用。在协同设计过程中,每个设计任务,特别是其中某些大任务的执行直接影响设计任务完成的时间,在本文中引入了资源预留机制,以便为其中的大任务提供动态预留资源5,进而提高协同设计的效率。下面讨论引入资源预留的网格协同设计任务调度模型。网

11、格协同设计任务执行的框架分为三个层次:由底而上依次为资源层、资源管理控制层和应用(用户)层。资源层是可以进行设计的实体DKU或者其他必要的资源,接受资源管理控制层的管理。应用层负责用户任务的提交和结果的反馈。资源管理控制层可以抽象为一个资源管理器,在控制管理器内设置了负责任务映射和资源预留请求的模块。网格协同设计任务调度系统模型示意图如图3所示。在图3中,在设计应用层和资源管理器之间省略了一个资源请求代理层。这是因为假定任务已经由资源请求代理指定为由该域完成。在这个域中,有多种系统资源,主要考虑计算资源和存储资源,在预留资源时既可能要预留计算资源也可能要预留存储资源及其他资源。当调度系统有预留的需求时,就通过创建预留操作向资源预留请求处理模块提出预留请求。资源信息由资源发现和资源监控提供。在该任务调度系统模型中,任务执行的大致流程如下:用户通过网格门户Portal将任务提交给资源请求代理;资源请求代理将任务分配给可以执行该任务的

温馨提示

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

评论

0/150

提交评论