mEDF: Deadline Driven Algorithm for Minimizing Response Time and Completion

advertisement
International Journal of Application or Innovation in Engineering & Management (IJAIEM)
Web Site: www.ijaiem.org Email: editor@ijaiem.org
Volume 3, Issue 6, June 2014
ISSN 2319 - 4847
mEDF: Deadline Driven Algorithm for
Minimizing Response Time and Completion
Time in IaaS Clouds
Vivek Shrivastava1, and D. S. Bhilare2
1
International Institute of Professional Studies, Devi Ahilya University, Indore, India
2
Computer Centre, Devi Ahilya University, Indore, India
Abstract
Cloud Computing is used to avail internet based services on a lease basis in a very short time period. Purchase and installation of
new computing resources takes time, so getting resources as a service from cloud in a minute or so is faster and cheaper
nowadays. A contract called service level agreement is worked between cloud host and consumer. SLA includes quality of service
(QoS) that must be provided by the cloud host to consumer. It also includes time frame, in that time period consumers’ task should
get done. Due to multi-tenancy architecture a cloud host has many consumers at same time. Some consumers cannot get their job
done in time limit. When rejecting consumers’ leases, deadline plays an important role. This paper introduces mEDF (Modified
Earliest Deadline First) algorithm and leasing policy for deadline driven resource management, which takes care of minimum
capacity expenses at cloud host side. Experiments and results show that this algorithm is suitable and can be used for deadline
driven scheduling with minimizing response time and completion time.
Keywords: Deadline, Resource management, IaaS cloud, mEDF.
1. INTRODUCTION
Cloud computing is the practice of using a network of remote servers hosted on the Internet to store, manage, and process
data, rather than a local server or a personal computer [1]. These remote servers show infinite capacity. Resources
provided by cloud can be increased or decreased on demand. Consumers have to pay only for what they have used. Proper
monitoring of SLA is done to provide QoS to consumers.
Clouds can be public, private or hybrid. In a public cloud many consumers from same or different organization can be
served at a time. In a private cloud, consumers only from the same organization are served from the cloud. Hybrid model
of cloud allows some services from its own resources and some from other cloud providers. Cloud Computing provides
three different types of services namely (1) Software as a Service (SaaS), (2) Platform as a Service (PaaS), and (3)
Infrastructure as a Service (IaaS).
In SaaS model of cloud, QoS-based workflow scheduling algorithm based on Partial Critical Paths (PCP) can be used [2].
PCP tries to minimize the cost of workflow execution while meeting a user-defined deadline. Recursively scheduling the
partial critical paths ending at previously scheduled tasks can also be done.
User defined deadline can also be provided in IaaS clouds. It may be a situation that a consumer’s task is to run in an
unattended mode with a predefined deadline that either provide resources in a given time frame or reject the request.
Haizea, which can be used as a plug-in scheduler for opennebula provides deadline driven scheduling [3]. This deadline
driven policy does not account for deadline sensitivity with minimizing computing capacity requirements to cloud host.
Our proposed policy and algorithm minimizes computing capacity requirements while keeping earliest deadline meeting
on the priority. Algorithm to minimize computing capacity requirement in deadline driven scheduling for different
consumers tasks are proposed in this paper. Experimental results are also shown to advocate the algorithm.
Rest of the paper is organized as: Section 2 contains related work. Section 3 describes need of introducing mEDF
algorithm for completing consumers’ task. In section 4, proposed algorithm, mEDF algorithm to minimize computing
capacity while meeting deadlines and implement better resource allocation policies, are given. Experimental results of
algorithm are presented in section 5. Section 6 contains conclusions and future work.
Figure 1 Consumers’ request, Revenue generation and deadline are interrelated to each other.
Volume 3, Issue 6, June 2014
Page 16
International Journal of Application or Innovation in Engineering & Management (IJAIEM)
Web Site: www.ijaiem.org Email: editor@ijaiem.org
Volume 3, Issue 6, June 2014
ISSN 2319 - 4847
2. LITERATURE SURVEY
Cloud Computing offers leasing computing capacity on a pay per use basis based on service level agreement. It saves time
and cost of installing hardware and software at consumers’ premises. Cloud provides services which are elastic in nature.
[4], [5].
Computing infrastructure is provided to consumer in the form of virtual machines that can be used for different types of
needs. IaaS service model provides tools and technologies in such a way that an organization’s existing hardware can be
used to provide hardware services to other organizations or same organization. So an organization can use a cloud for its
services or can become a cloud host and provide services to others [6].
In [7] provides an algorithm and a leasing policy for prioritizing consumers on the basis of CRI score. Authors showed
policy to maintain order of execution of users’ task on the basis of some parameters and claimed their result is an
improvement over existing policies and algorithms under some conditions.
Improvement on automated allocation and de-allocation of resources, resource monitoring, resource discovery and
registration are provided in [8]. This work increases chance of adoption of clouds by the consumers. [8], [9].
Aneka’s deadline-driven provisioning mechanism is given in [10]. This mechanism is responsible for supporting quality of
service (QoS)-aware execution of scientific applications in hybrid clouds. This mechanism can use and manage resources
obtained from same or a variety of sources that include desktop grids, clusters, grids, public and private clouds.
Particle Swarm Optimization (PSO) is utilized to schedule workflows in the algorithm proposed in [11]. This was
developed to work in clouds with a single-level SLAs and on-demand resource leasing. It does not consider workflow
deadlines, but focuses only on monetary cost minimization.
IaaS cloud can be setup by using toolkits OpenNebula [12], Eucalyptus [13], OpenStack [14] etc.. Currently, OpenNebula
scheduler provides an implementation of the Rank Scheduling Policy which aims to prioritize those resources more suitable
for the VM. Match making scheduler of OpenNebula works on the match making algorithm. This algorithm works on policy
from 0 to 4. 0th policy is packing, which Minimize the number of hosts in use by packing the VMs in the hosts to reduce
VM fragmentation, 1st policy is stripping, which Maximize resources available for the VMs by spreading the VMs in the
hosts policies provided. 2nd policy is load-aware that maximize resources available for the VMs by using those nodes with
less load. 3rd policy is Custom that uses a custom RANK. 4th policy is named Fixed in which, hosts will be ranked
according to the PRIORITY attribute found in the Host or Cluster template.
Haizea, a toolkit developed in Python to work as a custom scheduler for opennebula or in simulation mode was introduced
in [15]. New tailor made policies can be developed in Haizea. Haizea basically provides four types of leases: Best-effort
(BE), Advanced reservation, Immediate leases and Deadline sensitive leases [16]. BE leases are preemptable and breakable
i.e. resources can be given in different time intervals to every BE leases. BE leases does not have any time constraints, these
leases are served as and when lease load permits the system. Immediate and advance reservation (AR) leases are nonpreemptable and have time constraints, such as start time and end time. AR leases have more priority than BE leases for
resources. It will preempt best-effort leases whenever the resources are required for advance reservation. There is no
guarantee that a submitted best-effort lease will get resources for completion within a certain time limit [17].
If the system has lots of AR and immediate leases then priority will be given to these leases. BE leases have to wait for a
long time and will be served when resources are free from AR & immediate leases [18]. To protect these leases from
starvation, Starvation-removal algorithm was proposed in [19]. This algorithm supports very less suspensions of leases by
counting number of suspensions and then increases priority of that lease by aging mechanism.
BE leases takes long period of time to complete due to presence of so many AR and immediate leases. This may lead to
more requests to AR leases which in turn may cause internal fragmentation of free resources. Deadline sensitive (DLS)
leases can also be used with Haizea. DLS are assumed to be preemptable but there is a limitation to their preemptability. It
is preemptable only if the scheduling algorithm of Haizea can assure that it can be completed before its deadline. Thus, it
will assure (1) to consumers that their request will be completed within a certain time limit (2) minimum internal
fragmentation [20], [21], [22].
In [16], authors extended deadline sensitive algorithm of Haizea by considering several time slots that together can satisfy
complete lease within given deadline. Leases with same resource request or if first lease request has fewer resources then
second lease then only swapping of lease can be done to handle deadline situation. Other method proposed by the authors
was backfilling but unfortunately, they did not implement it and left it as future work.
In [24] authors proposed Auto-scaling approach to minimize cost and meet application deadlines in cloud workflows. In this
approach, the basic computing elements are virtual machines (VMs) of various sizes/costs, jobs. These VMs jobs are
specified as workflows. Users specify performance requirements by assigning (soft) deadlines to jobs, and the goal is to
ensure all jobs are finished within their deadlines at minimum financial cost. Authors proved their work by dynamically
allocating/deallocating VMs and scheduling tasks on the most cost-efficient instances.
The deadline-driven cost-minimization algorithm [25], or the Deadline-Markov Decision Process (MDP), breaks the
workflow into partitions. It assigns a maximum finishing time for each partition according to the deadline set by the user.
Based on this time, each partition is scheduled for that resource which will result in the lowest cost and earliest estimated
finishing time. This algorithm works with on-demand resource reservation.
Volume 3, Issue 6, June 2014
Page 17
International Journal of Application or Innovation in Engineering & Management (IJAIEM)
Web Site: www.ijaiem.org Email: editor@ijaiem.org
Volume 3, Issue 6, June 2014
ISSN 2319 - 4847
Deadline and Budget distribution-based Cost-Time Optimization (DBD-CTO) workflow scheduling algorithm was
proposed in [26]. This algorithm minimizes execution cost while meeting timeframe for delivering results, but this
algorithm’s work with real time workflows left as future work. In our work, we are applying earliest deadline first
algorithm [27] with a modification that, it should minimize the capacity required at cloud host side.
3. NEED OF MEDF ALGORITHM
Earliest deadline first (EDF) or least time to go is a dynamic scheduling algorithm. EDF is mostly used in real-time
operating systems to place processes in a priority queue. Processes are arranged in queue according to their deadlines.
Process queue is searched on every event of existing process finishes or a new process arrives for the process which is
closest to its deadline. This process is the next to be scheduled for execution [28].
In IaaS cloud environment, lease requests arrivals are independent. These lease requests can be characterized by arrival
time, duration and a deadline. Number of nodes required by the lease request can also be a factor that can play a vital role
for optimizing computing capacity requirement at cloud host side in scheduling. Our mEDF algorithm can take these factors
into account and can lead to improve waiting time and completion time of lease requests.
4. PROPOSED ALGORITHM
Algorithm required to implement mEDF policy are given in this section. Computing environment, test lease requests and
algorithm are described in next subsections.
Computing Environment
A collection of 4 nodes, all with one CPU and 1024MB of memory are used as system for testing in simulated mode of
Haizea tool kit.
<nodes>
<node-set numnodes="4">
<res type="CPU" amount="100"/>
<res type="Memory" amount="1024"/>
</node-set>
</nodes>
Sample Lease request
<lease-workload name="sample">
<description>
A simple trace where only one lease with deadline is specified is shown as sample here.
</description>
<lease-requests>
<!-- First lease request-->
<lease-request arrival="00:00:00">
<lease preemptible="true">
<nodes>
<node-set numnodes="2">
<res type="CPU" amount="100"/>
<res type="Memory" amount="1024"/>
</node-set>
</nodes>
<start></start>
<duration time="10:00:00"/>
<deadline>
<exact time="01-01-2014 00:00:00"/>
</deadline>
<software>
<disk-image id="foobar.img" size="1024"/>
</software>
</lease>
</lease-requests>
Volume 3, Issue 6, June 2014
Page 18
International Journal of Application or Innovation in Engineering & Management (IJAIEM)
Web Site: www.ijaiem.org Email: editor@ijaiem.org
Volume 3, Issue 6, June 2014
ISSN 2319 - 4847
Attributes and their sub attributes like lease, lease id, nodes, start, duration time, and software are already available with
Haizea installation. We have introduced new attribute deadline, so that a consumers’ tasks can be given a deadline. Monte
Carlo simulation is used for generating durations and Poisson distribution is used for lease request arrival times for
experiments.
Haizea may use backfilling algorithm with aggressive, conservative and off settings. We have used default aggressive
settings for our experiments. Rejection of leases which have crossed deadline limit has also been developed. Lease requests
arrive in their natural order. mEDF sorts all the lease requests in increasing order of deadline and number of nodes required
for leases and enqueue them time to time taking care of backfilling process.
Algorithm
Start
For all leases i = 1 to n do
Begin
Enqueue request as arrived in queue
Sort leases according to Deadline, number of number of nodes
If Numnodes_requested <= Numnodes_available and deadline >= available_schedule then
Accept lease
Else
Begin
Reject lease
If deadline >= available_schedule then
Reschedule lease
Else
Delete lease entry from queue
End
If lease completed then
Delete lease entry from queue
End
Stop
5. EXPERIMENTS AND RESULTS
Table-1 and Table-2 shows consumers’ lease requests under test run with existing DLS and mEDF algorithm respectively.
This batch of consumers’ lease requests is generated only for checking the validity of our proposed leasing policy and
algorithm in lab. Parameters Lid, Req. Arrival, Duration in days, Deadline, NumNodes, Response time are used in table,
where Lid is lease id usually given in ascending order in order of appearance of leases, Req. Arrival is date and time of
consumers’ lease request, Duration in days is also a parameter which specifies requested amount of time for cloud services ,
NumNodes is number of nodes required by consumer in present lease, and Response time is time at which first response
given to a particular lease and completion time is last date and time of providing nodes to consumers’ lease request.
Graph in figure-2 shows comparison between DLS algorithm and mEDF algorithm tested in Haizea tool kit.
Table -1: Deadline sensitive algorithm
Lid
7
Req. Arrival
01-01-2014 12:00
AM
01-01-2014 12:00
AM
01-01-2014 01:00
AM
02-01-2014 12:00
AM
03-01-2014 12:00
AM
04-01-2014 12:00
AM
05-01-2014 12:00
AM
8
05-01-2014 12:00
1
2
3
4
5
6
Volume 3, Issue 6, June 2014
Duration
in days
10
Deadline
14-01-2014
12:00 AM
12-01-2014
12:00 AM
09-01-2014
01:00 AM
16-02-2014
12:00 AM
19-02-2014
12:00 AM
07-02-2014
12:00 AM
18-01-2014
12:00 AM
3
17-02-2014
10
8
5
15
12
4
Num
Nodes
Response
time
Completion time
2
01-01-2014
10-01-2014
2
01-01-2014
08-01-2014
2
Rejected
Rejected
4
08-Jan-2014
25-01-2014
4
16-Jan-2014
07-02-2014
1
29-Jan-2014
01-02-2014
3
Rejected
Rejected
2
02-Feb-
05-02-2014
Page 19
International Journal of Application or Innovation in Engineering & Management (IJAIEM)
Web Site: www.ijaiem.org Email: editor@ijaiem.org
Volume 3, Issue 6, June 2014
9
10
AM
12:00 AM
2014
07-01-2014 12:00
AM
08-01-2014 12:00
AM
08-03-2014
12:00 AM
16-03-2014
12:00 AM
06-Feb2014
08-Feb2014
10
7
2
2
ISSN 2319 - 4847
16-02-2014
16-02-2014
Table 2: mEDF algorithm with same requests as in Table-1
Lid
1
2
3
4
5
6
7
8
9
10
Req. Arrival
01-01-2014 12:00
AM
01-01-2014 12:00
AM
01-01-2014 12:00
PM
02-01-2014 12:00
AM
03-01-2014 12:00
AM
04-01-2014 12:00
AM
05-01-2014 12:00
AM
05-01-2014 12:00
AM
07-01-2014 12:00
AM
08-01-2014 12:00
AM
Duration
in days
10
8
5
15
12
4
10
3
10
7
Deadline
14-01-2014
12:00 AM
12-01-2014
12:00 AM
09-01-2014
12:00 PM
16-02-2014
12:00 AM
19-02-2014
12:00 AM
07-02-2014
12:00 AM
18-01-2014
12:00 AM
17-02-2014
12:00 AM
08-03-2014
12:00 AM
16-03-2014
12:00 AM
Num
Nodes
Response
time
Completion time
2
Rejected
Rejected
2
01-01-2014
08-01-2014
2
01-01-2014
06-Jan-14
4
10-01-2014
26-Jan-14
4
16-01-2014
10-Feb-14
1
07-01-2014
11-Jan-14
3
Rejected
Rejected
2
27-01-2014
30-01-2014
2
01-02-2014
10-02-2014
2
26-01-2014
02-02-2014
Figure 2 Graph showing lease id and response times of DLS and mEDF algorithms.
Figure 3 Graph showing lease id and completion times of DLS and mEDF algorithms.
Volume 3, Issue 6, June 2014
Page 20
International Journal of Application or Innovation in Engineering & Management (IJAIEM)
Web Site: www.ijaiem.org Email: editor@ijaiem.org
Volume 3, Issue 6, June 2014
ISSN 2319 - 4847
6. CONCLUSION AND FUTURE WORK
mEDF algorithm implementation shows improvement in response time and completion time of various leases. This
algorithm can be very beneficial to cloud hosts and consumers. Proposed algorithm will automatically reject the leases,
which cannot be completed in time thus it saves resources for other leases and improves response time and completion time
of lease requests of consumers. Leases with scientific workloads will get most benefitted by this algorithm.
Future work may use experimenting same algorithm with backfilling algorithm’s conservative and off modes and provide a
comparative study of all deadline based algorithms. This work also suggests taking CRI score [7] along with mEDF
algorithm to improve resource utilization and revenue at cloud host.
References
[1] The Oxford Dictionary Website. [Online]. Available: http://www.oxforddictionaries.com/definition/english/cloudcomputing.
[2] S. Abrishami, and M. Naghibzadeh. “Deadline-constrained workflow scheduling in software as a service cloud,”
Scientia Iranica XIX (3), 680-689, 2012.
[3] Arshad, Junaid, Paul Townend, and Jie Xu. "Quantification of security for compute intensive workloads in clouds,"
In Proceedings of the 15th International Conference on Parallel and Distributed Systems (ICPADS), 2009, pp. 479486., 2009.
[4] V. Shrivastava, and D. S. Bhilare. “CBUD Micro: A Micro Benchmark for Performance Measurement and Resource
Management in IaaS Clouds,”International Journal of Emerging Technolgy and Advanced Engineering, III(11), pp.
433-437, 2013.
[5] Ostermann, Simon, Alexandria Iosup, Nezih Yigitbasi, Radu Prodan, Thomas Fahringer, and Dick Epema. "A
performance analysis of EC2 cloud computing services for scientific computing." In Cloud Computing, pp. 115-131.
Springer Berlin Heidelberg, 2010.
[6] Sotomayor, Borja, Rubén S. Montero, Ignacio M. Llorente, and Ian Foster. "Virtual infrastructure management in
private and hybrid clouds." Internet Computing, IEEE XIII (5), pp. 14-22, 2009.
[7] V. Shrivastava and D. S. Bhilare, “CRI: A Novel Rating Based Leasing Policy and Algorithm for Efficient Resource
Management in IaaS Clouds,”International Journal of Computer Science and Information Technologies, V (3), pp.
4226-4230, 2014.
[8] H. Mehta, P. Kanungo, and M. Chandwani.”"Performance enhancement of scheduling algorithms in web server
clusters using improved dynamic load balancing policies,” In Proceedings of the 2nd National Conference,
INDIACom-2008 Computing For Nation Development, pp. 651-656, 2008.
[9] Q. Zhang, L. Cheng, and R. Boutaba. “Cloud computing: state-of-the-art and research challenges,” Journal of
internet services and applications I (1), pp. 7-18, 2010.
[10] C. Vecchiola, C. Rodrigo, N. Calheiros, D. Karunamoorthy, and R. Buyya. “Deadline-driven provisioning of
resources for scientific applications in hybrid clouds with Aneka,” Future Generation Computer Systems XXVIII (1)
pp. 58-65, 2012.
[11] S. Pandey, L. Wu, M. G. Siddeswara, and R.Buyya. “A particle swarm optimization-based heuristic for scheduling
workflow applications in cloud computing environments,” In Proceedings of the 24th IEEE International Conference
on Advanced Information Networking and Applications (AINA), pp. 400-407, 2010.
[12] The OpenNebula Website. [Online]. Available: http://opennebula.org/.
[13] Eucalyptus Website. [Online]. Available: https://www.eucalyptus.com/eucalyptus-cloud/iaas [Accessed: Jan. 2, 2014].
[14] OpenStack Website. [Online]. Available: https://www.openstack.org/ [Accessed: Jan. 1, 2014].
[15] The Haizea Website. [Online]. Available: http://haizea.cs.uchicago.edu/ [Accessed: Jan. 1, 2014]..
[16] A. Nathani, S. Chaudhary, and G. Somani. “Policy based resource allocation in IaaS cloud,” Future Generation
Computer Systems XXVIII (1), 94-103, 2012.
[17] B.
Sotomayor.
“The
Haizea
Manual
on
Haizea,”
[Online].
Available:
http://haizea.cs.uchicago.edu/haizea_manual.pdf [Accessed: Jan. 1, 2014]..
[18] J. Akhani, S. Chuadhary, and G. Somani. “Negotiation for resource allocation in IaaS cloud,” In Proceedings of the
Fourth Annual ACM Bangalore Conference, pp. 15. ACM, 2011.
[19] V. Shrivastava, and D. S. Bhilare. “Algorithms to Improve Resource Utilization and Request Acceptance Rate in
IaaS Cloud Scheduling,” International Journal of Advanced Networking & Applications, III (5), pp. 1367-1374,
2012.
[20] B. Sotomayor, K. Keahey, and I. Foster. “Combining batch execution and leasing using virtual machines,” In
Proceedings of the 17th international symposium on High performance distributed computing, pp. 87-96, 2008.
[21] B. Sotomayor, R. S. Montero, I.M. Llorente, and I. Foster. “Capacity leasing in cloud systems using the opennebula
engine,”" In Workshop on Cloud Computing and its Applications, III. 2008.
Volume 3, Issue 6, June 2014
Page 21
International Journal of Application or Innovation in Engineering & Management (IJAIEM)
Web Site: www.ijaiem.org Email: editor@ijaiem.org
Volume 3, Issue 6, June 2014
ISSN 2319 - 4847
[22] B. Sotomayor, R.S. Montero, I. M. Llorente, and I. Foster. “Resource leasing and the art of suspending virtual
machine,” In Proceedings of 11th IEEE International Conference on High Performance Computing and
Communications, HPCC'09, pp. 59-68. 2009.
[23] D. Vora, S. Chaudhary, M. Bhise, V. Kumar, and G. Somani. “Allocation of slotted deadline sensitive leases in
infrastructure cloud,”, Distributed Computing and Internet Technology, pp. 242-252. Springer Berlin Heidelberg,
2012.
[24] M. Mao and M. Humphrey. “Auto-scaling to minimize cost and meet application deadlines in cloud workflows,” In
Proceedings of 2011 International Conference for High Performance Computing, Networking, Storage and Analysis,
pp. 49, 2011.
[25] J. Yu, R. Buyya, and C. K. Tham. “Cost-based scheduling of scientific workflow applications on utility grids,” In
Proceedings of the First International Conference on e-Science and Grid Computing, 2005., pp. 8, 2005.
[26] A. Verma, and S. Kaushal. “Deadline and budget distribution based cost-time optimization workflow scheduling
algorithm for cloud,” In Proceedings of the IJCA on International Conference on Recent Advances and Future
Trends in Information Technology (iRAFIT’12), pp. 1-,. 2012.
[27] P. Brucker, Scheduling algorithms, 5th ed, Berlin: Springer-Verlag, 2007.
[28] The Wikipedia Website. [Online]. Available:http://en.wikipedia.org/wiki/Scheduling_algorithm, [Accessed: Jan. 1,
2014].
AUTHORS
Vivek Shrivastava is pursuing Ph. D. in CS from DAVV under the guidance of Dr. D.S. Bhilare. He is
M.Tech. (Computer Sc.), MCA, and UGC-NET qualified in Computer Sc. & Applications. Working as an
Assistant Professor in International Institute of Professional Studies, Devi Ahilya University, Indore. His areas
of interest are Cloud Computing, Ubiquitous Computing and Information Security.
D.S. Bhilare received his Ph.D. (Computer Science), M.Tech. (Computer Sc.), M.Phil. (Computer Sc.) and
MBA from Devi Ahilya University, Indore. Worked as a senior project leader for ten years in the industry and
developed various business applications for different industries. Since last twenty years, working in the
University as a Senior Manager & Head Computer Centre. He has presented several papers in national and international
conferences and published in reputed journals and international conference proceedings in the area of Information
Security.
Volume 3, Issue 6, June 2014
Page 22
Download