• No results found

Lect 7: Introduction to MapReduce

N/A
N/A
Protected

Academic year: 2022

Share "Lect 7: Introduction to MapReduce"

Copied!
22
0
0

Loading.... (view fulltext now)

Full text

(1)

Lect 7: Introduction to MapReduce

November 1, 2017

(2)

Outline

1. Introduction to Mapreduce

2. Understanding Mapreduce with example 3. Understanding Mapreduce and its phases 4. Understanding Key-value pair

5. Understanding Wordcount program

(3)

Introduction to Mapreduce

MapReduce is the data processing layer of Hadoop. It is a software framework for easily writing applications that process the vast amount of structured and unstructured data stored in the Hadoop Distributed Filesystem (HDFS). It processes the huge amount of data in parallel by dividing the job (submitted job) into a set of independent tasks (sub-job). By this parallel processing speed and reliability of cluster is improved. We just need to put the custom code (business logic) in the way map reduce works and rest things will be taken care by the engine.

(4)

Understanding Mapreduce with example

Let governor of Californina make you the head of census bureau for the state of California and you are tasked with finding the population of all cities in California. You have all the resources you want but you have only 4 months to finish the task.

Calculating the population of all cities in a big state like California is not an easy task for any one person. So the sensible thing to do is divide the state by city and make individuals incharge of each city to calculate the population of each city he/she is incharge of. Just for illustration purpose, lets focus on only 3 cities ? San Fransisco, San JOSE, and LA. Person 1 will be incharge of SFO, Person 2 will be incharge of San Jose and Person 3 will be incharge of LA.

(5)
(6)

Understanding Mapreduce with example

Let governor of Californina asks to finish up the task in 2 months: strategy

(7)

Understanding Mapreduce with Unix command

Below is the command in Unix to count occurrences of each distinct word appearing in the file entered.

words(abc.txt) | sort | uniq -c map: (words(abc.txt))

1. scan input file line by line

2. extract results in form of key (something we care about while coding) Sort and Shuffle: sort

1. grouping of words with same key 2. passing the resultant file to next phase Reduce: counts uniq occurrences of each word.

(8)

Introducing Mapreduce and its phases

MapReduce is a programming model for distributed computing. It is not a programming language, it is a model which you can use to process huge datasets in a distributed fashion. before are the phases involved in MapReduce.

(9)

Introduction to Mapreduce

1. Input Files: The data for a MapReduce task is stored in input files, and input files typically lives in HDFS. The format of these files is arbitrary, while line-based log files and binary format can also be used.

(10)

2. InputFormat : It defines how these input files are split and read. It selects the files or other objects that are used for input. InputFormat creates InputSplit.

3. InputSplits : t is created by InputFormat, logically represent the data which will be processed by an individual Mapper (We will understand mapper below). One map task is created for each split; thus the number of map tasks will be equal to the number of InputSplits. The split is divided into records and each record will be processed by the mapper.

4. RecordReader: It communicates with the InputSplit in Hadoop

MapReduce and converts the data into key-value pairs suitable for reading by the mapper. By default, it uses TextInputFormat for converting data into a key-value pair. RecordReader communicates with the InputSplit until the file reading is not completed. It assigns byte offset (unique number) to each line present in the file. Further, these key-value pairs are sent to the mapper for further processing.

5. Mapper: It processes each input record (from RecordReader) and

generates new key-value pair, and this key-value pair generated by Mapper is completely different from the input pair. The output of Mapper is also known as intermediate output which is written to the local disk.

(11)

6. Combiner : The combiner is also known as ?Mini-reducer?. Hadoop MapReduce Combiner performs local aggregation on the mappers?

output, which helps to minimize the data transfer between mapper and reducer (we will see reducer below). Once the combiner functionality is executed, the output is then passed to the partitioner for further work.

7. Partitioner Hadoop MapReduce, Partitioner comes into the picture if we are working on more than one reducer (for one reducer partitioner is not used). Partitioner takes the output from combiners and performs

partitioning. Partitioning of output takes place on the basis of the key and then sorted. By hash function, key (or a subset of the key) is used to derive the partition. According to the key value in MapReduce, each combiner output is partitioned, and a record having the same key value goes into the same partition, and then each partition is sent to a reducer.

Partitioning allows even distribution of the map output over the reducer.

8. Shuffling and Sorting : the output is Shuffled to the reduce node (which is a normal slave node but reduce phase will run here hence called as reducer node). The shuffling is the physical movement of the data which is done over the network. Once all the mappers are finished and their output is shuffled on the reducer nodes, then this intermediate output is merged and sorted, which is then provided as input to reduce phase.

(12)

9. Reducer: It takes the set of intermediate key-value pairs produced by the mappers as the input and then runs a reducer function on each of them to generate the output. The output of the reducer is the final output, which is stored in HDFS.

(13)

Understanding Key-value pair

In MapReduce process, before passing the data to the mapper, data should be first converted into key-value pairs as mapper only understands key-value pairs of data. key-value pairs in Hadoop MapReduce is generated as follows:

1. InputSplit : It is the logical representation of data. The data to be processed by an individual Mapper is presented by the InputSplit.

2. RecordReader : It communicates with the InputSplit and it converts the Split into records which are in form of key-value pairs that are suitable for reading by the mapper. By default, RecordReader uses TextInputFormat for converting data into a key-value pair. RecordReader communicates with the InputSplit until the file reading is not completed.

In MapReduce, map function processes a certain key-value pair and emits a certain number of key-value pairs and the Reduce function processes values grouped by the same key and emits another set of key-value pairs as output.

The output types of the Map should match the input types of the Reduce as shown below:

Map: (K1, V1) → list (K2, V2) Reduce: (K2, list (V2 ) list (K3, V3)

(14)

Understanding Key-value pair Map: (K1, V1) → list (K2, V2) Reduce: (K2, list (V2 ) list (K3, V3)

Example : Consider a file containing following two lines : a, abc, abcd, bc

b ,abc, a, bcd

Input to map : (0, (a, abc, abcd, bc)) , (1, (b, abc, a, bcd))

Output from map : ((a, 1), (abc, 1), (abcd, 1), (bc, 1)) , ((b, 1), (abc, 1), (a, 1), (bcd, 1)). “List”

Combiner : ( (a, (1,1), (abc, (1,1), (abcd, (1)), (bc, (1)), (b, 1), (bcd, 1))) Reducer : ((a, 2), (abc, 2), (abcd, 1), (bc, 1), (b,1), (bcd, 1))

(15)

Understanding word count example

(16)

Understanding mapreduce - aggregation example

(17)

Understanding WordCount example Source code:

Figure:WordCount program

(18)

Figure:WordCount program

(19)

Figure:WordCount program explanation

(20)

Figure:WordCount program

(21)

Figure:WordCount program explanation

(22)

Figure:WordCount program

References

Related documents