· papers · 2 min read
MapReduce: Simplified Data Processing on Large Clusters
Author(s): Jeffrey Dean and Sanjay Ghemawat
Date: 2004
Notes
- MapReduce
- “Users specify a map function that processes a key/value pair to generate a set of intermediate key/value pairs, and a reduce function that merges all intermediate values associated with the same intermediate key.”
- Used for processing large data sets
- Programs can be parallelized and executed on large clusters of machines, making it highly scalable
- Drawbacks
- The distributed nature can have significant drawbacks if there is a lot of network latency between the machines
- Examples
- Distributed Grep - The map function creates a line if it matches the pattern, the reduce function copies the intermediate data to the output
- Count of URL Access Frequency - The map function processes logs of web page requests and outputs, the reduce function adds together all va lues for the same URL with a total count per URL pair
- In Practice
- A user writes both the map and the reduce function for their dataset
- The master computer divides the dataset into M map functions and R reduce functions and sends the details to the corresponding number of workers
- Map workers perform the map function and then store the output on their local disks
- Reduce workers reach out to the correct map workers (orchestrated by the master program) to get the data they need to perform the reduce function
- Reduce workers output the result to R number of output files, which are then sent back to the user program by the master computer once the work is completed