Download presentation
Presentation is loading. Please wait.
1
Distributed Computations MapReduce/Dryad
M/R slides adapted from those of Jeff Dean’s Dryad slides adapted from those of Michael Isard
2
What we’ve learnt so far
Basic distributed systems concepts Consistency (sequential, eventual) Concurrency Fault tolerance (recoverability, availability) What are distributed systems good for? Better fault tolerance Better security? Increased storage/serving capacity Storage systems, clusters Parallel (distributed) computation (Today’s topic)
3
Why distributed computations?
How long to sort 1 TB on one computer? One computer can read ~60MB from disk Takes ~1 days!! Google indexes 100 billion+ web pages 100 * 10^9 pages * 20KB/page = 2 PB Large Hadron Collider is expected to produce 15 PB every year!
4
Solution: use many nodes!
Cluster computing Hundreds or thousands of PCs connected by high speed LANs Grid computing Hundreds of supercomputers connected by high speed net 1000 nodes potentially give 1000X speedup
5
Distributed computations are difficult to program
Sending data to/from nodes Coordinating among nodes Recovering from node failure Optimizing for locality Debugging Same for all problems
6
MapReduce A programming model for large-scale computations
Process large amounts of input, produce output No side-effects or persistent state (unlike file system) MapReduce is implemented as a runtime library: automatic parallelization load balancing locality optimization handling of machine failures
7
MapReduce design Input data is partitioned into M splits
Map: extract information on each split Each Map produces R partitions Shuffle and sort Bring M partitions to the same reducer Reduce: aggregate, summarize, filter or transform Output is in R result files
8
More specifically… Programmer specifies two methods:
map(k, v) → <k', v'>* reduce(k', <v'>*) → <k', v'>* All v' with same k' are reduced together, in order. Usually also specify: partition(k’, total partitions) -> partition for k’ often a simple hash of the key allows reduce operations for different k’ to be parallelized
9
Example: Count word frequencies in web pages
Input is files with one doc per record Map parses documents into words key = document URL value = document contents Output of map: “to”, “1” “be”, “1” “or”, “1” … “doc1”, “to be or not to be”
10
Example: word frequencies
Reduce: computes sum for a key Output of reduce saved key = “not” values = “1” “1” key = “or” values = “1” “1” key = “to” values = “1”, “1” “2” key = “be” values = “1”, “1” “2” “be”, “2” “not”, “1” “or”, “1” “to”, “2”
11
Example: Pseudo-code Map(String input_key, String input_value): //input_key: document name //input_value: document contents for each word w in input_values: EmitIntermediate(w, "1"); Reduce(String key, Iterator intermediate_values): //key: a word, same for input and output //intermediate_values: a list of counts int result = 0; for each v in intermediate_values: result += ParseInt(v); Emit(AsString(result));
12
MapReduce is widely applicable
Distributed grep Document clustering Web link graph reversal Detecting approx. duplicate web pages …
13
MapReduce implementation
Input data is partitioned into M splits Map: extract information on each split Each Map produces R partitions Shuffle and sort Bring M partitions to the same reducer Reduce: aggregate, summarize, filter or transform Output is in R result files
14
MapReduce scheduling One master, many workers
Input data split into M map tasks (e.g. 64 MB) R reduce tasks Tasks are assigned to workers dynamically Often: M=200,000; R=4,000; workers=2,000
15
MapReduce scheduling Master assigns a map task to a free worker
Prefers “close-by” workers when assigning task Worker reads task input (often from local disk!) Worker produces R local files containing intermediate k/v pairs Master assigns a reduce task to a free worker Worker reads intermediate k/v pairs from map workers Worker sorts & applies user’s Reduce op to produce the output
16
Parallel MapReduce Input data Map Map Map Map Master Reduce Shuffle
Partitioned output
17
WordCount Internals Input data is split into M map jobs
Each map job generates in R local partitions “to”, “1” “be”, “1” “or”, “1” “not”, “1 “to”,“1”,”1” Hash(“to”) % R R local partitions “doc1”, “to be or not to be” “be”,“1” “not”,“1” “or”, “1” “doc234”, “do not be silly” “do”, “1” “not”, “1” “be”, “1” “silly”, “1 “be”,“1” R local partitions “not”,“1” “do”,“1”
18
WordCount Internals Shuffle brings same partitions to same reducer
“do”,“1” “be”,“1”,”1” “not”,“1”,”1” “or”, “1” “to”,“1”,”1” “be”,“1” R local partitions “not”,“1” “or”, “1” “do”,“1” R local partitions “be”,“1” “not”,“1”
19
WordCount Internals Reduce aggregates sorted key values pairs “do”,“1”
“to”, “2” “be”,“2” “not”,“2” “or”, “1” “to”,“1”,”1” “be”,“1”,”1” “not”,“1”,”1” “or”, “1”
20
The importance of partition function
partition(k’, total partitions) -> partition for k’ e.g. hash(k’) % R What is the partition function for sort?
21
Load Balance and Pipelining
Fine granularity tasks: many more map tasks than machines Minimizes time for fault recovery Can pipeline shuffling with map execution Better dynamic load balancing Often use 200,000 map/5000 reduce tasks w/ 2000 machines
22
Fault tolerance via re-execution
On worker failure: Re-execute completed and in-progress map tasks Re-execute in progress reduce tasks Task completion committed through master On master failure: State is checkpointed to GFS: new master recovers & continues
23
Avoid straggler using backup tasks
Slow workers significantly lengthen completion time Other jobs consuming resources on machine Bad disks with soft errors transfer data very slowly Weird things: processor caches disabled (!!) An unusually large reduce partition? Solution: Near end of phase, spawn backup copies of tasks Whichever one finishes first "wins" Effect: Dramatically shortens job completion time
24
MapReduce Sort Performance
1TB (100-byte record) data to be sorted 1700 machines M=15000 R=4000
25
MapReduce Sort Performance
When can shuffle start? When can reduce start?
26
Slides adapted from those of Yuan Yu and Michael Isard
Dryad Slides adapted from those of Yuan Yu and Michael Isard
27
Dryad Similar goals as MapReduce Computations expressed as a graph
focus on throughput, not latency Automatic management of scheduling, distribution, fault tolerance Computations expressed as a graph Vertices are computations Edges are communication channels Each vertex has several input and output edges
28
WordCount in Dryad Count Word:n MergeSort Word:n Distribute Word:n
29
Why using a dataflow graph?
Many programs can be represented as a distributed dataflow graph The programmer may not have to know this “SQL-like” queries: LINQ Dryad will run them for you
30
Runtime Vertices (V) run arbitrary app code
Vertices exchange data through files, TCP pipes etc. Vertices communicate with JM to report status V Let us move back to discussing the graph execution. The Job Manager (JM) handles the scheduling of all the processes in the vertices of the graph. It does this using a topological sort of the graph. When nodes in the graph fail execution, parts of the subgraph may need to be re-executed, because the inputs that are needed may no longer be available. The vertices that had generated these inputs may have to be re-run. The JM will attempt to re-execute a minimal part of the graph to recompute the missing data. On executing a vertex, the JM must choose a machine Daemon process (D) executes vertices Job Manager (JM) consults name server(NS) to discover available machines. JM maintains job graph and schedules vertices
31
Job = Directed Acyclic Graph
Outputs Processing vertices Channels (file, pipe, shared memory) A dryad application is composed of a collection of processing vertices (processes). The vertices communicate with each other through channels. The vertices and channels should always compose into a directed acyclic graph. Inputs
32
Scheduling at JM General scheduling rules:
Vertex can run anywhere once all its inputs are ready Prefer executing a vertex near its inputs Fault tolerance If A fails, run it again If A’s inputs are gone, run upstream vertices again (recursively) If A is slow, run another copy elsewhere and use output from whichever finishes first
33
Advantages of DAG over MapReduce
Big jobs more efficient with Dryad MapReduce: big job runs >=1 MR stages reducers of each stage write to replicated storage Output of reduce: 2 network copies, 3 disks Dryad: each job is represented with a DAG intermediate vertices write to local file
34
Advantages of DAG over MapReduce
Dryad provides explicit join MapReduce: mapper (or reducer) needs to read from shared table(s) as a substitute for join Dryad: explicit join combines inputs of different types Dryad “Split” produces outputs of different types Parse a document, output text and references
35
DAG optimizations: merge tree
36
DAG optimizations: merge tree
37
Dryad Optimizations: data-dependent re-partitioning
Distribute to equal-sized ranges Sample to estimate histogram Randomly partitioned inputs
38
Dryad example 1: SkyServer Query
3-way join to find gravitational lens effect Table U: (objId, color) 11.8GB Table N: (objId, neighborId) 41.8GB Find neighboring stars with similar colors: Join U+N to find T = N.neighborID where U.objID = N.objID, U.color Join U+T to find U.objID where U.objID = T.neighborID and U.color ≈ T.color
39
SkyServer query D M 4n S Y H n X U N select u.color,n.neighborobjid
from u join n where u.objid = n.objid u: objid, color n: objid, neighborobjid [partition by objid]
40
D M 4n S Y H n X U N [distinct] [merge outputs]
(u.color,n.neighborobjid) [re-partition by n.neighborobjid] [order by n.neighborobjid] select u.objid from u join <temp> where u.objid = <temp>.neighborobjid and |u.color - <temp>.color| < d
41
Dryad example 2: Query histogram computation
Input: log file (n partitions) Extract queries from log partitions Re-partition by hash of query (k buckets) Compute histogram within each bucket
42
Naïve histogram topology
P parse lines D hash distribute S quicksort C count occurrences MS merge sort Q R k n is : Each MS C P S D
43
Efficient histogram topology
P parse lines D hash distribute S quicksort C count occurrences MS merge sort M non-deterministic merge k Each Q' is : Each T k R R C Each is : R S D T is : P C C Q' M MS MS n
44
P parse lines D hash distribute S quicksort MS merge sort
MS►C R R R MS►C►D T M►P►S►C Q’ P parse lines D hash distribute S quicksort MS merge sort C count occurrences M non-deterministic merge
45
P parse lines D hash distribute S quicksort MS merge sort
MS►C R R R MS►C►D T M►P►S►C Q’ Q’ Q’ Q’ P parse lines D hash distribute S quicksort MS merge sort C count occurrences M non-deterministic merge
46
P parse lines D hash distribute S quicksort MS merge sort
MS►C R R R MS►C►D T T M►P►S►C Q’ Q’ Q’ Q’ P parse lines D hash distribute S quicksort MS merge sort C count occurrences M non-deterministic merge
47
P parse lines D hash distribute S quicksort MS merge sort
MS►C R R R MS►C►D T T M►P►S►C Q’ Q’ Q’ Q’ P parse lines D hash distribute S quicksort MS merge sort C count occurrences M non-deterministic merge
48
P parse lines D hash distribute S quicksort MS merge sort
MS►C R R R MS►C►D T T M►P►S►C Q’ Q’ Q’ Q’ P parse lines D hash distribute S quicksort MS merge sort C count occurrences M non-deterministic merge
49
P parse lines D hash distribute S quicksort MS merge sort
MS►C R R R MS►C►D T T M►P►S►C Q’ Q’ Q’ Q’ P parse lines D hash distribute S quicksort MS merge sort C count occurrences M non-deterministic merge
50
Final histogram refinement
Q' R 450 T 217 10,405 99,713 33.4 GB 118 GB 154 GB 10.2 TB 1,800 computers 43,171 vertices 11,072 processes 11.5 minutes
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.