SCHEDULING MAP AND REDUCE TASKS FOR JOBS EXECUTION ACCORDING TO PERFORMANCE GOALS

Information

  • Patent Application
  • 20140019987
  • Publication Number
    20140019987
  • Date Filed
    April 19, 2011
    13 years ago
  • Date Published
    January 16, 2014
    11 years ago
Abstract
Allocations of resources are determined for jobs that have map tasks and reduce tasks. The jobs are ordered according to performance goals of the jobs. The tasks of the jobs are scheduled for execution according to the ordering and the allocations of resources for the respective jobs.
Description
BACKGROUND

Many enterprises (such as companies, educational organizations, and government agencies) employ relatively large volumes of data that are often subject to analysis. A substantial amount of the data of an enterprise can be unstructured data, which is data that is not in the format used in typical commercial databases. Existing infrastructures may not be able to efficiently handle the processing of relatively large volumes of unstructured data.





BRIEF DESCRIPTION OF THE DRAWINGS

Some embodiments are described with respect to the following figures:



FIG. 1 is a block diagram of an example arrangement that incorporates some implementations;



FIGS. 2A-2B are graphs illustrating map tasks and reduce tasks of a job in a MapReduce environment, according to some examples;



FIG. 3 is a flow diagram of a process of scheduling execution of tasks of jobs, in accordance with some implementations;



FIGS. 4A-4B are graphs illustrating feasible solutions representing respective allocations of map slots and reduce slots, determined according to some implementations; and



FIG. 5 is a flow diagram of a process of scheduling execution of tasks of jobs, in accordance with further implementations.





DETAILED DESCRIPTION

For processing relatively large volumes of unstructured data, a MapReduce framework provides a distributed computing platform can be employed. Unstructured data refers to data not formatted according to a format of a relational database management system. An open-source implementation of the MapReduce framework is Hadoop. The MapReduce framework is increasingly being used across enterprises for distributed, advanced data analytics and for enabling new applications associated with data retention, regulatory compliance, e-discovery, and litigation issues. The infrastructure associated with the MapReduce framework can be shared by various diverse applications, for enhanced efficiency.


Generally, a MapReduce framework includes a master node and multiple slave nodes (also referred to as worker nodes). A MapReduce job submitted to the master node is divided into multiple map tasks and multiple reduce tasks, which are executed in parallel by the slave nodes. The map tasks are defined by a map function, while the reduce tasks are defined by a reduce function. Each of the map and reduce functions are user-defined functions that are programmable to perform target functionaliities.


The map function processes segments of input data to produce intermediate results, where each of the multiple map tasks (that are based on the map function) process corresponding segments of the input data. For example, the map tasks process input key-value pairs to generate a set of intermediate key-value pairs. The reduce tasks (based on the reduce function) produce an output from the intermediate results. For example, the reduce tasks merge the intermediate values associated with the same intermediate key.


More specifically, the map function takes input key-value pairs (k1, v1) and produces a list of intermediate key-value pairs (k2, v2). The intermediate values associated with the same key k2 are grouped together and then passed to the reduce function. The reduce function takes an intermediate key k2 with a list of values and processes them to form a new list of values (v3), as expressed below.





map(k1,v1)→list(k2,v2)





reduce(k2,list(v2))→list(v3)


The multiple map tasks and multiple reduce tasks (of multiple jobs) are designed to be executed in parallel across resources of a distributed computing platform.


In a complex system, it can be relatively difficult to efficiently allocate resources to jobs and to schedule the tasks of the jobs for execution using the allocated resources, while meeting performance goals of the jobs. The jobs to be executed in a system can have different performance goals—some jobs can be jobs performed in response to queries where the requesters expect relatively quick responses, while other jobs can be long production jobs (e.g. backup jobs, archiving jobs, etc.) that can run a relatively long time.


In accordance with some implementations, mechanisms or techniques are provided to specify efficient allocations of resources to jobs and to schedule jobs using the allocated resources in a manner to allow performance goals of the jobs to be satisfied, A scheduler according to some implementations is provided to determine job ordering and scheduling of tasks of corresponding jobs. The ordering of jobs can be according to respective performance goals of the jobs. The scheduler also receives as input resource allocations for the respective jobs. The resource allocations are determined based on employing a performance model that takes into account job profiles (of the respective jobs), where the determined allocations are able to satisfy the performance goals associated with the respective jobs. Given the ordering of the jobs and the determined resource allocations, the scheduler is able to schedule tasks of the jobs for execution.


In some implementations, the performance goal associated with a job can be expressed as a target completion time, which can be a specific deadline, or some other indication of a time duration within which the job should be executed. Other performance goals can be used in other examples. For example, a performance goal can be expressed as a service level objective (SLO), which specifies a level of service to be provided (expected performance, expected time, expected cost, etc.).


Although reference is made to the MapReduce framework in some examples, it is noted that techniques or mechanisms according to some implementations can be applied in other distributed processing frameworks that employ map tasks and reduce tasks. More generally, “map tasks” are used to process input data to output intermediate results, based on a predefined function that defines the processing to be performed by the map tasks. “Reduce tasks” take as input partitions of the intermediate results to produce outputs, based on a predefined function that defines the processing to be performed by the reduce tasks. The map tasks are considered to be part of a map stage, whereas the reduce tasks are considered to be part of a reduce stage. In addition, although reference is made to unstructured data in some examples, techniques or mechanisms according to some implementations can also be applied to structured data formatted for relational database management systems.



FIG. 1 illustrates an example arrangement that provides a distributed processing framework that includes mechanisms according to some implementations. As depicted in FIG. 1, a storage subsystem 100 includes multiple storage modules 102, where the multiple storage modules 102 can provide a distributed file system 104. The distributed file system 104 stores multiple segments 106 of input data across the multiple storage modules 102. The distributed file system 104 can also store outputs of map and reduce tasks.


The storage modules 102 can be implemented with storage devices such as disk-based storage devices or integrated circuit storage devices, in some examples, the storage modules 102 correspond to respective different physical storage devices. In other examples, plural ones of the storage modules 102 can be implemented on one physical storage device, where the plural storage modules correspond to different logical partitions of the storage device.


The system of FIG. 1 further includes a master node 110 that is connected to slave nodes 112 over a network 114. The network 114 can be a private network (e.g., a local area network or wide area network) or a public network (e.g., the Internet), or some combination thereof. The master node 110 includes one or multiple central processing units (CPUs) 124. Each slave node 112 also includes one or multiple CPUs (not shown). Although the master node 110 is depicted as being separate from the slave nodes 112, it is noted that in alternative examples, the master node 112 can be one of the slave nodes 112.


A “node” refers generally to processing infrastructure to perform computing operations. A node can refer to a computer, or a system having multiple computers. Alternatively, a node can refer to a CPU within a computer. As yet another example, a node can refer to a processing core within a CPU that has multiple processing cores. More generally, the system can be considered to have multiple processors, where each processor can be a computer, a system having multiple computers, a CPU, a core of a CPU, or some other physical processing partition.


In accordance with some implementations, a scheduler 108 in the master node 110 is configured to perform scheduling of jobs on the slave nodes 112. The slave nodes 112 are considered the working nodes within the cluster that makes up the distributed processing environment.


Each slave node 112 has a corresponding number of map slots and reduce slots, where map tasks are run in respective map slots, and reduce tasks are run in respective reduce slots. The number of map slots and reduce slots within each slave node 112 can be preconfigured, such as by an administrator or by some other mechanism. The available map slots and reduce slots can be allocated to the jobs. The map slots and reduce slots are considered the resources used for performing map and reduce tasks. A “slot” can refer to a time slot or alternatively, to some other share of a processing resource that can be used for performing the respective map or reduce task. Depending upon the load of the overall system, the number of map slots and number of reduce slots that can be allocated to any given job can vary.


The slave nodes 112 can periodically (or repeatedly) send messages to the master node 110 to report the number of free slots and the progress, of the tasks that are currently running in the corresponding slave nodes.


Each map task processes a logical segment of the input data that generally resides on a distributed file system, such as the distributed file system 104 shown in FIG. 1. The map task applies the map function on each data segment and buffers the resulting intermediate data. This intermediate data is partitioned for input to the reduce tasks.


The reduce stage (that includes the reduce tasks) has three phases: shuffle phase, sort phase, and reduce phase. In the shuffle phase, the reduce tasks fetch the intermediate data from the map tasks. In the sort phase, the intermediate data from the map tasks are sorted. An external merge sort is used in case the intermediate data does not fit in memory. Finally, in the reduce phase, the sorted intermediate data (in the form of a key and all its corresponding values, for example) is passed on the reduce function. The output from the reduce function is usually written back to the distributed file system 104.


In addition to the scheduler 108, the master node 110 of FIG. 1 includes a job profiler 120 that is able to create a job profile for a given job, in accordance with some implementations. The job profile describes characteristics of map and reduce tasks of the given job to be performed by the system of FIG. 1. A job profile created by the job profiler 120 can be stored in a job profile database 122. The job profile database 122 can store multiple job profiles, including job profiles of jobs that have executed in the past.


The master node 110 also includes a resource estimator 116 that is able to allocate resources, such as numbers map slots and reduce slots, to a job, given a performance goal (e.g., target completion time) associated with the job. The resource estimator 116 receives as input a job profile, which can be a job profile created by the job profiler 120, or a job profile previously stored in the job profile database 122. The resource estimator 116 also uses a performance model that calculates a performance parameter (e.g., time duration of the job) based on the characteristics of the job profile, a number of map tasks of the job, a number of reduce tasks of the job, and an allocation of resources (e.g., number of map slots and number of reduce slots).


Using the performance parameter calculated by the performance model, the resource estimator 116 is able to determine feasible allocations of resources to assign to the given job to meet the performance goal associated with the given job. As noted above, in some implementations, the performance goal is expressed as a target completion time, which can be a target deadline or a target time duration, by or within which the job is to be completed. In such implementations, the performance parameter that is calculated by the performance model is a time duration value corresponding to the amount of time the job would take assuming a given allocation of resources. The resource estimator 116 is able to determine whether any particular allocation of resources can meet the performance goal associated with a job by comparing a value of the performance parameter calculated by the performance model to the performance goal.


As noted above, the resource estimator 116 is able to calculate multiple feasible solutions of allocations of resources to perform a given job, where a “feasible solution” refers to an allocation of resources that allows a system to execute the given job while satisfying the performance goal associated with the given job. The multiple feasible solutions of allocations of resources for the given job can be added to a set of feasible solutions. Then, using some predefined criterion, one of the feasible solutions can be selected from the set to determine a specific allocation of resources for the given job.


In accordance with some implementations, the resource estimator 116 is able to select one of the feasible solutions that is associated with a minimum amount of allocated resources (e.g. minimum total number of map and reduce slots) that allows the given job to meet its performance goal. In some implementations, the selection of the feasible solution with the minimum amount of allocated resources uses a Lagrange's multiplier technique, which is a technique that finds a maxima or minima of a function subject to constraints. A Lagrange's multiplier technique according to some implementations is discussed further below. In other implementations, the resource estimator 116 can use other techniques for selecting from among multiple feasible solutions for output as a selected solution that includes a specific allocation of resources.


As shown in FIG. 1, the scheduler 108 receives the following inputs job profiles from the job profiler 120 and/or profile database 122, and a specific allocation of resources from the resource estimator 116.


The scheduler 108 is able to listen for events such as job submissions, heartbeats from the slave nodes 118 (indicating availability of map and/or reduce slots, and/or other events). The scheduling functionality of the scheduler 108 can be performed in response to detected events.


The scheduler 108 is able to order the jobs to be executed according to performance goals of the respective jobs. For example, if the performance goals are corresponding deadlines of the jobs, the scheduler 108 is able to employ an earliest deadline first technique to perform job ordering, where the job with the earliest deadline is ordered ahead of other jobs. Effectively, the earliest deadline first technique orders jobs starting with the job having the earliest deadline, and progressing to the job with the latest deadline, in other implementations, other ordering techniques for ordering a collection of jobs can be used.


According to the allocated amount of resources for each job and the ordering of the jobs, the scheduler 108 is able to schedule tasks of jobs to respective map and reduce slots. In alternative implementations, there can be different classes of jobs, including jobs with deadlines and jobs without deadlines. The scheduler 108 can assign jobs with deadlines higher priorities over jobs without deadlines. However, once jobs with deadlines are assigned their respective allocations of map and reduce slots, the remaining slots can be distributed to other classes of jobs.


The scheduling of job tasks in respective slots (as performed by the scheduler 108) is provided as output to a resource allocator 126, which performs the assignment of tasks to respective slots (according to the scheduling). The resource allocator 126 ensures that the number of map and reduce slots assigned to any given job remains below allocated numbers for each given job as provided by the resource estimator 116. Note that if there are spare slots that are unused, the resource allocator 126 can employ further policy to use such slots for performing tasks of jobs.


Although the scheduler 108 and resource allocator 126 are depicted as separate modules in FIG. 1, note that in alternative implementations, the functionalities of the scheduler 108 and resource allocator 126 can be combined into one module. Alternatively, the functionalities of the resource estimator 116 and/or job profiler 120 can also be combined with another module. Also, although each of the modules 108, 116, 120, 126, and 122 are depicted as being part of the master node 110, it is noted that some of such modules can be deployed on another node.


The following describes implementations where the performance goal associated with a job is a target completion time (a deadline or time duration of the job). Note that techniques or mechanisms according to other implementations can be employed with other types of performance goals.



FIGS. 2A and 2B illustrate differences in completion times of performing map and reduce tasks of a given job due to different allocations of map slots and reduce slots. FIG. 2A illustrates an example in which there are 64 map slots and 64 reduce slots allocated to the given job. The example also assumes that the total input data to be processed for the given job can be separated into 64 partitions. Since each partition is processed by a corresponding different map task, the given job includes 64 map tasks. Similarly, 64 partitions of intermediate results output by the map tasks can be processed by corresponding 64 reduce tasks. Since there are 64 map slots allocated to the map tasks, the execution of the given job can be completed in a single map wave.


As depicted in FIG. 2A, the 64 map tasks are performed in corresponding 64 map slots 202, in a single wave (represented generally as 204). Similarly, the 64 reduce tasks are performed in corresponding 64 reduce slots 206, also in a single reduce wave 208, which includes shuffle, sort, and reduce phases represented by different line patterns in FIG. 2A.


A “map wave” refers to an iteration of the map stage. If the number of allocated map slots is greater than or equal to the number of map tasks, then the map stage can be completed in a single iteration (single wave). However, if the number of map slots allocated to the map stage is less than the number of map tasks, then the map stage would have to be completed in multiple iterations (multiple waves). Similarly, the number of iterations (waves) of the reduce stage is based on the number of allocated reduce slots as compared to the number of reduce tasks.



FIG. 2B illustrates a different allocation of map slots and reduce slots. Assuming the same given job (input data that is divided into 64 partitions), if the number of resources allocated is reduced to 16 map slots and 22 reduce slots, for example, then the completion time for the given job will change (increase). FIG. 2B illustrates execution of map tasks in the 16 map slots 210. In FIG. 2B, instead of performing the map tasks in a single wave as in FIG. 2A, the example of FIG. 2B illustrates four waves 212A, 212B, 212C, and 212D of map tasks. The reduce tasks are performed in the 22 reduce slots 214, in three waves 216A, 216B, and 216C. The completion time of the given job in the FIG. 2B example is greater than the completion time in the FIG. 2A example, since a smaller amount of resources was allocated to the given job in the FIG. 2B example than in the FIG. 2A example.


Thus, it can be observed from the examples of FIGS. 2A and 2B that the execution times of any given job can vary when different amounts of resources are allocated to the job.



FIG. 3 is a flow diagram of a process of scheduling jobs for execution as performed by the master node 110 of FIG. 1, in accordance with some implementations. The process includes receiving (at 302) job profiles that define characteristics of respective jobs to be executed. The jobs that are to be executed are ordered (at 304) according to respective performance goals (e.g., deadlines) of respective ones of the jobs. For example, as noted above, the ordering can be based on using an earliest deadline first technique. The ordering can be performed by the scheduler 108 (FIG. 1).


The master node 110 also determines (at 306) a respective allocation of resources for each of the jobs based on the corresponding job profile. This task can be performed by the resource estimator 116. For example, the resource estimator 116 can select an allocation of resources (e.g. number of map slots and number of reduce slots) for each job by selecting the allocation with the minimum amount of resources (e.g. minimum total number of map and reduce slots). The selected allocation can be from among multiple feasible solutions.


Based on the ordering of the jobs and the respective allocated amounts of resources for the jobs, the scheduler can schedule (at 308) tasks (including map tasks and reduce tasks) of the jobs for execution.


Further details regarding the job profile, performance model, determination of solutions of resource allocations, and scheduling of job tasks are discussed below.


A job profile reflects performance invariants that are independent of the amount of resources assigned to the job over time, for each of the phases of the job: map, shuffle, sort, and reduce phases. The job profile properties for each of such phases are provided below.


The map stage includes a number of map tasks. To characterize the distribution of the map task durations and other invariant properties, the following metrics can be specified in some examples.





(Mmin,Mavg,Mmax,AvgSizeMinput,SelectivityM), where

    • Mmin is the minimum map task duration. Since the shuffle phase starts when the first map task completes, Mmin is used as an estimate for the shuffle phase beginning.
    • Mavg is the average duration of map tasks to indicate the average duration of a map wave.
    • Mmax is the maximum duration of a map task. Since the sort phase of the reduce stage can start only when the entire map stage is complete. i.e., all the map tasks complete, Mmax is used as an estimate for a worst map wave completion time.


AvgSizeMinput is the average amount of input data for a map stage. This parameter is used to estimate the number of map tasks to be spawned for a new data set processing.

    • SelectivityM is the ratio of the map data output size to the map data input size. It is used to estimate the amount of intermediate data produced by the map stage as the input to the reduce stage (note that the size of the input data to the map stage is known).


As described earlier, the reduce stage includes the shuffle, sort and reduce phases. The shuffle phase begins only after the first map task has completed. The shuffle phase (of any reduce wave) completes when the entire map stage is complete and all the intermediate data generated by the map tasks have been shuffled to the reduce tasks.


The completion of the shuffle phase is a prerequisite for the beginning of the sort phase. Similarly, the reduce phase begins only after the sort phase is complete. In alternative implementations instead of performing the shuffle and sort phases of the reduce stage sequence, for enhanced performance efficiency, the shuffle and sort phases of the reduce stage can be interleaved. The profiles of the shuffle, sort, and reduce phases are represented by their average and maximum time durations. In addition, for the reduce phase, the reduce selectivity, denoted as SelectivityR, is computed, which is defined as the ratio of the reduce data output size to its data input size.


The shuffle phase of the first reduce wave may be different from the shuffle phase that belongs to the subsequent reduce waves (after the first reduce wave). This can happen because the shuffle phase of the first reduce wave overlaps with the map stage and depends on the number of map waves and their durations. Therefore, two sets of measurements are collected: (SHavg1, Shmax1) for a shuffle phase of the first reduce wave (referred to as to the “first shuffle phase”, and (Shavgtyp, Shmaxtyp) for the shuffle phase of the subsequent reduce waves (referred to as “typical shuffle phase”). Since techniques according to some implementations are looking for the performance invariants that are independent of the amount of allocated resources to the job, a shuffle phase of the first reduce wave is characterized in a special way and the parameters (Shavg1 and Shmax1) reflect only durations of the non-overlapping portions (non-overlapping with the map stage) of the first shuffle. In other words, the durations represented by Shavg1 and Shmax1 represent portions of the duration of the shuffle phase of the first reduce wave that do not overlap with the map stage.


The job profile in the shuffle phase is characterized by two pairs of measurements:





(Shavg1,Shmax1),(Shavgtyp,Shmaxtyp).


If the job execution has only a single reduce wave, the typical shuffle phase duration is estimated using the sort benchmark (since the shuffle phase duration is defined entirely by the size of the intermediate results output by the map stage).


A performance model used for determining a feasible allocation of resources for a job calculates a performance parameter. In some implementations, the performance parameter can be expressed as an upper bound parameter or a lower bound parameter or some determined intermediate parameter between the lower bound and upper bound (e.g. average of the lower and upper bounds). In implementations where the performance parameter is a completion time value, the lower bound parameter is a lower bound completion time, the upper bound parameter is an upper bound completion time, and the intermediate performance parameter is an intermediate completion time (e.g. average completion time that is an average of the upper and lower completion). In other implementations, instead of calculating the average of the upper bound and lower bound to provide the intermediate performance parameter, a different intermediate parameter can be calculated, such as a value based on a weighted average of the lower and upper bounds or application of some other predefined function on the lower and upper bounds.


In some examples, the lower and upper bounds are for a makespan (a completion time of the job) of a given set of n (n>1) tasks that are processed by k (k>1) servers (or by k slots in a MapReduce environment). Let T1, T2, . . . Tn be the durations of n tasks of a given job. Let k be the number of slots that can each execute one task at a time. The assignment of tasks to slots is done using a simple, online, greedy algorithm, e.g. assign each task to the slot with the earliest finishing time.


Let μ=(Σi=1nTi)/n and λ=max1 {Ti} be the mean and maximum durations of the n tasks, respectively. The makespan of the greedy task assignment is at least n·μ/k and at most (n−1)·λ/k+λ. The lower bound is trivial, as the best case is when all n tasks are equally distributed among the k slots (or the overall amount of work n·μ processed as fast as it can by k slots). Thus, the overall makespan (completion time of the job) is at least n·μ/k (lower bound of the completion time).


For the upper bound of the completion time for the job, the worst case scenario is considered, i.e., the longest task (T)ε(T1, T2, . . . Tn) with duration λ is the last task processed. In this case, the time elapsed before the last task is scheduled is (Σi=1n-1Ti)/k≦(n−1)·μ/k. Thus, the makespan of the overall assignment is at most (n−1)·μ/k+λ. These bounds are particularly useful when λ<<n·μ/k, in other words, when the duration of the longest task is small as compared to the total makespan.


The difference between tower and upper bounds (of the completion time) represents the range of possible job completion times due to non-determinism and scheduling. As discussed below, these lower and upper bounds, which are part of the properties of the performance model, are used to estimate a completion time for a corresponding job J.


The given job J has a given profile created by the job profiler 120 (FIG. 1) or extracted from the profile database 122. Let J be executed with a new input dataset that can be partitioned into NM map tasks and NR reduce tasks. Let SM and SR be the number of map slots and number of reduce slots, respectively, allocated to job J.


Let Mavg and Mmax be the average and maximum time durations of map tasks (defined by the job J profile). Then, based on the Makespan theorem, the lower and upper bounds on the duration of the entire map stage (denoted as TMlow and TMup, respectively) are estimated as follows:






T
M
low
=N
M
J
/S
M
J
·M
avg,  (Eq. 1)






T
M
up=(NMJ−1)/SMJ·Mavg+Mmax.  (Eq. 2)


The “J” superscript in NMJ and SMJ indicates that the respective parameter is associated with job J. Stated differently, the lower bound of the duration of the entire map stage is based on a product of the average duration (Mavg) of map tasks multiplied by the ratio of the number of map tasks (NMJ) to the number of allocated map slots (SMJ). The upper bound of the duration of the entire map stage is based on a sum of the maximum duration of map tasks (Mmax) and the product of Mavg with (NMJ−1)/SMJ. Thus, it can be seen that the lower and upper bounds of durations of the map stage are based on properties of the job J profile relating to the map stage, and based on the allocated number of map slots.


The reduce stage includes shuffle, sort and reduce phases. Similar to the computation of the lower and upper bounds of the map stage, the lower and upper bounds of time durations for each of the shuffle phase (TShlow, TSup), sort phase (TSortlow, TSortup), and reduce phase (TRlow, TRup) are computed. The computation of the Makespan theorem is based on the average and maximum durations of the tasks in these phases (respective values of the average and maximum time durations of the shuffle phase, the average and maximum time durations of the sort phase, and the average and maximum time duration of the reduce phase) and the numbers of reduce tasks NR and allocated reduce slots SR, respectively. The formulae for calculating (TShlow, TShup), (TSortlow, TSortup), and (TRlow, TRup) are similar to the formulae for calculating TMup and TMup set forth above, except variables associated with the reduce tasks and reduce slots and the respective phases of the reduce stage are used instead.


The subtlety lies in estimating the duration of the shuffle phase. As noted above, the first shuffle phase is distinguished from the task durations in the typical shuffle phase (which is a shuffle phase subsequent to the first shuffle phase). As noted above, the first shuffle phase includes measurements of a portion of the first shuffle phase that does not overlap the map stage. The portion of the typical shuffle phase in the subsequent reduce waves (after the first reduce wave) is computed as follows:











T
Sh
low

=


(



N
R
J


S
R
J


-
1

)

·

Sh
avg
typ



,




(

Eq
.




3

)







T
Sh
up

=



(




N
R
J

-
1


S
R
J


-
1

)

·

Sh
avg
typ


+


Sh
max
typ

.






(

Eq
.




4

)







where Shavgtyp is the average duration of a typical shuffle phase, and Shmaxtyp is the average duration of the typical shuffle phase. The formulae for the lower and upper bounds of the overall completion time of job J are as follows:






T
J
low
=T
M
low
+Sh
avg
1
+T
Sh
low
+T
Sort
low
+T
R
low,  (Eq. 5)






T
J
up
=T
M
up
+Sh
max
1
+T
Sh
up
+T
Sort
up
+T
R
up.  (Eq. 6)


where Shavg1 is the average duration of the first shuffle phase, and Shmax1 is the maximum duration of the first shuffle phase. TJlow and TJup represent optimistic and pessimistic predictions (tower and upper bounds) of the job J completion time. Thus, it can be seen that the lower and upper bounds of time durations of the job J are based on properties of the job J profile and based on the allocated numbers of map and reduce slots. The properties of the performance model, which include TJlow and TJup in some implementations, are thus based on both the job profile as well as allocated numbers of map and reduce slots.


In some implementations, an intermediate performance parameter value, such as an average value between the lower and upper bounds, TJavg is defined as follows:






T
J
avg=(TMup+)TJlow/2.  (Eq. 7)


Eq. 5 for TJlow can be rewritten by replacing its parts with Eq. 1 and Eq. 3 and similar equations for sod and reduce phases as follows:











T
J
low

=




N
M
J

·

M
avg



S
M
J


+



N
R
J

·

(


Sh
avg
typ

+

R
avg


)



S
R
J


+

Sh
avg
1

-

Sh
avg
typ



,




(

Eq
.




8

)







The alternative presentation of Eq. 8 allows the estimates for completion time to be expressed in a simplified form shown below:











T
J
low

=



A
J
low

·


N
M
J


S
M
J



+


B
J
low

·


N
R
J


S
R
J



+

C
J
low



,




(

Eq
.




9

)







where AJlow=Mavg, BJlow=(Shavgtyp+Ravg), and CJlow=Shavg1−Shavgtyp. Eq. 9 provides an explicit expression of a job completion time as a function of map and reduce slots allocated to job J for processing its map and reduce tasks, i.e., as a function of (NMJ, NRJ) and (SMJ, SRJ). The equation for and TJup and Tavg J can be rewritten similarly.


The following discusses how an allocation with a minimum number of map and reduce slots can be determined using a Lagrange's multiplier technique according to some implementations.


The allocations of map and reduce slots to job J (with a known profile) for meeting deadline T can be found using Eq. 9 or similar equations for the upper bound or the average completion time. A simplified form of this equation is shown below:












a
m

+

b
r


=
D

,




(

Eq
.




10

)







where m is the number of map slots allocated to the job J, r is the number of reduce slots allocated to the job J, and a, b and D represent the corresponding constants (expressions) from Eq. 9 or similar other equations for TJup and TJavg.


As shown in FIG. 4A, Eq. 10 yields a curve 402 if t and rare the variables. All points on this curve 402 are feasible allocations of map and reduce slots for job J which result in meeting the same deadline T. As shown in FIG. 4A, allocations can include a maximum number of map slots and very few reduce slots (shown as point A along curve 402) or very few map slots and a maximum number of reduce slots (shown as point B along curve 402).


These different feasible resource allocations (represented by points along the curve 402) correspond to different amounts of resources that allow the deadline T to be satisfied. FIG. 4B shows a curve 404 that relates a sum of allocated map slots and reduce slots (vertical axis of FIG. 4B) to a number of map slots (horizontal axis of FIG. 4B). There is a point along curve 404 where the sum of the map and reduce slots is minimized (shown as point C along curve 404 in FIG. 4B). Thus, the resource estimator 116 (FIG. 1) aims to find the point where the sum of the map and reduce slots is minimized (shown as point C). By allocating the allocation with a minimum of the summed number of map slots and reduce slots, the number of map and reduce slots allocated to job j is reduced to allow available slots to be allocated to other jobs.


The minima (C) on the curve 404 can be calculated using Lagrange's multiplier technique. The technique seeks to minimize f(m, r)=m+r over








a
m

+

b
r


=

D
.





The technique sets







Λ
=

m
+
r
+

λ






a
m


+

λ






b
r


D



,




where λ represents a Lagrange multiplier.


Differentiating A partially with respect to n, r and λ and equating to zero, the following are obtained:













Λ



m


=


1
-

λ






a

m
2




=
0


,




(

Eq
.




11

)










Λ



r


=


1
-

λ






b

r
2




=
0


,
and




(

Eq
.




12

)









Λ



λ


=



1
m

+

b
r

-
D

=
0.





(

Eq
.




13

)







Solving these equations simultaneously, the variables m and r are obtained.










m
=



a



(


a

+

b


)


D


,





r
=




b



(


a

+

b


)


D

.






(

Eq
.




14

)







These values for m (number of map slots) and r (number of reduce slots) reflect the optimal allocation of map and reduce slots for a job such that the total number of slots used is minimized while meeting the deadline of the job. In practice, the m and r values are integers—hence, the values found by Eq. 14 are rounded up and used as approximations.


A specific technique that can be performed by the master node 110 (FIG. 1) is set forth in the pseudocode below.















1:
When job j is added:


2:
Fetch Profilej from database


3:
Compute minimum number of map and reduce slots (mj,rj) using



Lagrange's multiplier method


4:
When a heartbeat is received from node n:


5:
Sort jobs in order of earliest deadline


6:
for each slot s in free map/reduce slots on node n do


7:
 for each job j in jobs do


8:
  if RunningMapsj < mj and s is map slot then


9:
   if job j has unlaunched map task t with data on node n then


10:
    Launch map task t with local data on node n


11:
   else if j has unlaunched map task t then


12:
    Launch map task t on node n


13:
   end if


14:
  end if


15:
  if FinishedMapsj > 0 and s is reduce slot and



  RunningReducesj < rj then


16:
   if job j has unlaunched reduce task t then


17:
    Launch reduce task t on node n


18:
   end if


19:
  end if


20:
 end for


21:
end for


22:
for each task Tj finished slots by node n do


23:
 Recompute (mj,rj) based on the current time, current progress and



 deadline of job j


24:
end for









The pseudocode above is explained in connection with FIG. 5. The process of FIG. 5 can be performed by various modules in the master node 110 of FIG. 1. When a job j is added to the system, as detected at 502 (line 1 of pseudocode), the respective profile for the job j is fetched (at 504, line 2 of pseudocode). The profile for job j can be received from the profile database 122 or from the job profiler 120.


The master node 110 further determines (at 506, line 3 of pseudocode) the minimum allocation of resources (the allocation with the minimum total number of map and reduce slots) for job j, such as by use of the Lagrange's multiplier technique discussed above). This minimum allocation of resources is represented as (mj, rj), where mj represents the allocated number of map slots, and rj represents the number of reduce slots.


The master node 110 further determines (at 508, line 4 of the pseudocode) if a heartbeat is received from slave node n. A heartbeat is sent by a slave node to indicate availability of a slot (map slot and/or reduce slot). In response to the heartbeat, the master node 110 orders (at 510, line 5 of the pseudocode) a data structure jobs, which contains the jobs that are to be executed in the system. The ordering of jobs in the data structure jobs can be in an order of earliest deadline.


Next, for each free slot s (free map slot or free reduce slot) and for each job j in jobs, the master node 110 launches (at 512) map tasks and/or reduce tasks according to predefined criteria, as specified in lines 6-21 of the pseudocode. Since the jobs in the data structure jobs are sorted according to the deadlines of the jobs, the processing performed at lines 6-21 of the pseudocode would consider jobs with earlier deadlines before jobs with later deadlines.


Line 8 of the pseudocode determines if a parameter RunningMapsj is less than the number of map slots allocated to job j (mj), and if the free slot (s) is a map slot. The parameter RunningMapsj represents the how may map slots are already used for executing map tasks of job j. If the condition at line 8 of the pseudocode is true, then line 9 of the pseudocode determines if job j has an unlaunched map task t with data on node n—if so, then this map task t is launched with local data on node n (line 10 of the pseudocode). The pseudocode at lines 9-10 favor execution of a map task t that has data on node n—the availability of local data on node n for the map task t increases efficiency of execution since network communication is reduced or avoided in executing task t on node n.


However if there is no map task t with local data on node n, line 11 of the pseudocode checks if job j has unlaunched map task t—if so, then map task t is launched on node n (line 12 of the pseudocode). Note that the map task t launched at line 12 may not have local data on node n.


Line 15 of the pseudocode checks to see if there are any finished map tasks for job j (based on determining if FinishedMapsj>0)—this check is performed since reduce tasks are performed after at least one map task completes. The parameter FinishedMapsj indicates a number of map tasks that have completed. Also, line 15 checks to determine if free slot (s) is a reduce slot, and if the number of reduce slots used by job j (RunningReducesj) is less than rj—if all three conditions of line 15 are true, then an unlaunched reduce task t from job j is launched (lines 16-17 of the pseudocode.


Line 22 of the pseudocode checks (at 514) to see if any task (map task or reduce task) has completed in node n. If so, then the minimum allocation of map slots and reduce slots (mj, rj) can be recomputed (at 516) based on a current time, a current progress of job j, and the deadline of job j (line 23 of the pseudocode). The recomputing of the minimum allocation of map and reduce slots allows the system to ensure that the job j has sufficient resources to meets its deadline, given the progress of the job j. At any given point in time, the number of available map and/or reduce slots can be less than the number of map and reduce slots specified by a minimum allocation for job j. As a result, the job j may not be able to progress as quickly as anticipated, since insufficient resources are assigned to the job. The recomputation of the resource allocation for job j increases the likelihood that job j will be executed in time to meets its respective deadline.


Machine-readable instructions described above (including the various modules depicted in FIG. 1 and the pseudocode depicted above) are loaded for execution on a processor (such as 124 in FIG. 1). A processor can include a microprocessor, microcontroller, processor module or subsystem, programmable integrated circuit, programmable gate array, or another control or computing device.


Data and instructions are stored in respective storage devices, which are implemented as one or multiple computer-readable or machine-readable storage media. The storage media include different forms of memory including semiconductor memory devices such as dynamic or static random access memories (DRAMs or SRAMs), erasable and programmable read-only memories (EPROMs), electrically erasable and programmable read-only memories (EEPROMs) and flash memories; magnetic disks such as fixed, floppy and removable disks other magnetic media including tape; optical media such as compact disks (CDs) or digital video disks (DVDs); or other types of storage devices. Note that the instructions discussed above can be provided on one computer-readable or machine-readable storage medium, or alternatively, can be provided on multiple computer-readable or machine-readable storage media distributed in a large system having possibly plural nodes. Such computer-readable or machine-readable storage medium or media is (are) considered to be part of an article (or article of manufacture). An article or article of manufacture can refer to any manufactured single component or multiple components. The storage medium or media can be located either in the machine running the machine-readable instructions, or located at a remote site from which machine-readable instructions can be downloaded over a network for execution.


In the foregoing description, numerous details are set forth to provide an understanding of the subject disclosed herein. However, implementations may be practiced without some or all of these details. Other implementations may include modifications and variations from the details discussed above. It is intended that the appended claims cover such modifications and variations.

Claims
  • 1. A method of a system having a processor, comprising: receiving job profiles of respective jobs, wherein each of the job profiles describes characteristics of map tasks and reduce tasks, wherein the map tasks produce intermediate results based on input data, and the reduce tasks produce an output based on the intermediate results;ordering the jobs according to performance goals of respective ones of the jobs;determining a respective allocation of resources for each of the jobs based on the corresponding job profile; andscheduling map tasks and reduce tasks of the jobs for execution according to the ordering and the respective allocations of resources for the jobs.
  • 2. The method of claim 1, wherein the performance goals comprise deadlines of the corresponding jobs, and wherein ordering the jobs is according to the deadlines.
  • 3. The method of claim 2, wherein ordering the jobs provides an order of the jobs where a given one of the jobs with an earliest deadline from among the deadlines of the jobs is first in the order.
  • 4. The method of claim 1, wherein determining the respective allocation of the resources for each of the jobs comprises determining a minimum allocation of the resources for each of the jobs.
  • 5. The method of claim 4, wherein determining the minimum allocation of the resources uses a Lagrange's multiplier technique.
  • 6. The method of claim 1, wherein determining the respective allocation of the resources for each of the jobs comprises determining the respective allocation of map slots and reduce slots, where the map tasks of the respective job are performed in the map slots, and the reduce tasks of the respective job are performed in the reduce slots.
  • 7. The method of claim 6, wherein the map slots and reduce slots are provided in plural nodes of a distributed computing platform.
  • 8. The method of claim 1, wherein determining the allocation of resources for a particular one of the jobs uses a performance model that calculates a performance parameter based on the characteristics of the job profile for the particular job, a number of the map tasks of the particular job, a number of the reduce tasks of the particular job, and an allocation of resources for the particular job.
  • 9. The method of claim 1, further comprising: upon completion of a given one of the scheduled tasks, recomputing the allocation of the resources for the job that the given scheduled task is part of.
  • 10. An article comprising at least one machine-readable storage medium storing instructions that upon execution cause a system having a processor to perform a method according to any of claims 1-9.
  • 11. A system comprising: a plurality of worker nodes having resources; andat least one processor to: determine a corresponding allocation of resources for each of a plurality of jobs to be executed, wherein each of the jobs has a map stage having map tasks to produce an intermediate result based on input data, and a reduce stage having reduce tasks to produce an output based on the intermediate result;order the jobs according to performance goals of the jobs; andschedule the map tasks and reduce tasks of the plurality of jobs for execution according to the ordering and the allocations of resources for the respective jobs.
  • 12. The system of claim 11, wherein the resources in the plurality of worker nodes include map slots and reduce slots, wherein the map slots are used to perform respective ones of the map tasks in the map stages of the plurality of jobs, and the reduce slots are used to perform respective ones of the reduce tasks in the reduce stages of the plurality of jobs.
  • 13. They system of claim 12, wherein the determined allocation of resources for each of the plurality of jobs includes an allocation having a minimum number of a total number of map slots and reduce slots that allows the respective job to meet the corresponding performance goal.
  • 14. The system of claim 11, wherein the performance goals include deadlines of the jobs, and the ordering of the jobs is according to the deadlines such that an order of jobs is provided in which jobs with earlier deadlines are ahead of jobs with later deadlines, and wherein the scheduling of the tasks of the plurality of jobs for execution processes the jobs according to the order.
  • 15. The system of claim 11, wherein the scheduling of the tasks provides higher priority to tasks having local data on a particular one of the worker nodes that is being considered for scheduling tasks.
PCT Information
Filing Document Filing Date Country Kind 371c Date
PCT/US11/32969 4/19/2011 WO 00 10/2/2013