[发明专利]一种云环境下BoT任务的快速调度方法在审

专利信息
申请号: 201711023219.3 申请日: 2017-10-27
公开(公告)号: CN107908466A 公开(公告)日: 2018-04-13
发明(设计)人: 孙晋;张毅;董韵;冒晶晶;孙露露;何爱清;张华旭;龚炎 申请(专利权)人: 南京理工大学
主分类号: G06F9/48 分类号: G06F9/48
代理公司: 南京理工大学专利中心32203 代理人: 薛云燕
地址: 210094 江*** 国省代码: 江苏;32
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 环境 bot 任务 快速 调度 方法
【说明书】:

技术领域

发明涉及云计算技术领域,特别是一种云环境下BoT任务的快速调度方法。

背景技术

云计算旨在通过互联网将可用资源(包括计算资源、平台资源和应用资源)以服务的形式提供给用户。用户以“用多少、付多少”的方式使用这些资源。因此,云计算特别适合处理那些需要大量计算资源的任务。

Bag-of-Tasks(BoT)任务是一类包含多个可并行处理作业的任务。BoT任务是指包含多个可并行处理作业的任务,广泛存在于计算机视频、图片处理、蒙特卡罗仿真的科学和工程领域。事实上,很多用户(包括企业或者机构)都已有一些有限资源的计算设备(可称为私有云),但是不能高效调度BoT任务使得最大完工时间(即makespan)最小化。

发明内容

本发明的目的在于提供一种云环境下BoT任务的快速调度方法,从而快速有效地确定每个作业的开始时间并最小化makespan。

实现本发明目的的技术解决方案为:一种云环境下BoT任务的快速调度方法,步骤如下:

步骤1,信息读取:读取BoT任务的所有参数;

步骤2,作业调度:基于读取的参数,确定所有作业的开始时间;

步骤3,作业执行:按照步骤2的结果执行各个作业。

进一步地,所述BoT任务的所有参数包括:所有BoT任务中各作业的处理时间,各任务所需的VM类型。

进一步地,所述基于读取的参数,确定所有作业的开始时间,所采用的作业调度方法如下:

假设一个私有云CP0,私有云提供了k个VM类型,分别为VM1,VM2,…,VMk

每个VMq都用两个配置参数来描述:该VM所能提供的CPU数量CPUq和内存的数量Memq,q=1,2,…,k;

一共有n个BoT任务a1,a2,…,an,每个任务ai包含Ti个作业用一个参数xiq表示ai是否需要VMq,如果需要则xiq=1;否则,xiq=0;每个作业的处理时间为rij,其中i=1,2,…,n,j=1,2,…,Ti

时间轴以1小时的粒度离散化,私有云最大CPU数量和内存数量分别表示为CPU*和Mem*,即在时间轴上的任何一点私有云上所消耗的资源不能超过CPU*和Mem*

设任务ai的完工时间为ci,时间轴的最大时间戳S=maxi=1,2,…,nci;设cij为作业tij的完工时间,故有:

若作业tij的开始时间为stij,那么cij如下:

cij=stij+rij (2)

定义决策变量zijs,i=1,2,…,n,j=1,2,…,Ti,s=0,1,…,S;zijs=1表明作业tij的开始时间为s,否则zijs=0,把作业tij的开始时间描述成整数规划问题,即Minimize the makespan(Cmax):

Cmax=maxi=1,2,…,nci (3)

s.t.

上述作业调度方法从作业的失败时刻的下一时刻起确定作业的开始时间,需要结合私有云最大CPU数量CPU*和内存数量Mem*,且满足公式(3)~(5)的约束。

进一步地,作业调度方法具体如下:

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于南京理工大学,未经南京理工大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201711023219.3/2.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top