0% found this document useful (0 votes)
74 views20 pages

CCD-333 Exam Tutorial

Download as pdf or txt
Download as pdf or txt
Download as pdf or txt
You are on page 1/ 20

11/13/2019 CCD-333 Exam Tutorial

Cloudera CCD-333 Exam Tutorial

Question No : 1

If you run the word count MapReduce program with m mappers and r reducers, how many
output files will you get at the end of the job? And how many key-value pairs will there be in
each file? Assume k is the number of unique words in the input files.

A. There will be r files, each with exactly k/r key-value pairs.


B. There will be r files, each with approximately k/m key-value pairs.
C. There will be r files, each with approximately k/r key-value pairs.
D. There will be m files, each with exactly k/m key value pairs.
E. There will be m files, each with approximately k/m key-value pairs.

Answer: A
Explanation: Note: *A MapReduce job withm mappers and r reducers involves up to m*r distinct copy operations, since
eachmapper may have intermediate output going to every reducer. *In the canonical example of word counting, a key-value pair
is emitted for every word found. For example, if we had 1,000 words, then 1,000 key-value pairs will be emitted from the
mappers to the reducer(s).

Question No : 2

When is the reduce method first called in a MapReduce job?

A. Reduce methods and map methods all start at the beginning of a job, in order to provide optimal performance for
map-only or reduce-only jobs.
B. Reducers start copying intermediate key value pairs from each Mapper as soon as it has completed. The reduce
method is called as soon as the intermediate key-value pairs start to arrive.
C. Reducers start copying intermediate key-value pairs from each Mapper as soon as it has completed. The reduce
method is called only after all intermediate data has been copied and sorted.
D. Reducers start copying intermediate key-value pairs from each Mapper as soon as it has completed. The programmer
can configure in the job what percentage of the intermediate data should arrive before the reduce method begins.

Answer: C
Explanation: In a MapReduce job reducers do not start executing the reduce method until the all Map jobs have completed.
Reducers start copying intermediate key-value pairs from the mappers as soon as they are available. The programmer defined
reduce method is called only after all the mappers have finished. Reference:24 Interview Questions & Answers for Hadoop
MapReduce developers,When is the reducers are started in a MapReduce job? http://www.fromdev.com/2010/12/interview-
questions-hadoop-mapreduce.html(question no. 17)

Question No : 3

In a MapReduce job, you want each of you input files processed by a single map task. How
do you configure a MapReduce job so that a single map task processes each input file
regardless of how many blocks the input file occupies?

A. Increase the parameter that controls minimum split size in the job configuration.
B. Write a custom MapRunner that iterates over all key-value pairs in the entire file.
C. Set the number of mappers equal to the number of input files you want to process.
D. Write a custom FileInputFormat and override the method isSplittable to always return false.

Answer: D
Explanation: Note: *// Do not allow splitting. protected boolean isSplittable(JobContext context, Path filename) { return false; }
*InputSplits: An InputSplit describes a unit of work that comprises a single map task in a MapReduce program. A MapReduce
program applied to a data set, collectively referred to as a Job, is made up of several (possibly several hundred) tasks. Map tasks
may involve reading a whole file; they often involve reading only part of a file. By default, the FileInputFormat and its
descendants break a file up into 64 MB chunks (the same size as blocks in HDFS). You can control this value by setting the

https://www.exam-labs.com/exam/CCD-333 1/20
11/13/2019 CCD-333 Exam Tutorial
mapred.min.split.size parameter in hadoop-site.xml, or by overriding the parameter in the JobConf object used to submit a
particular MapReduce job. By processing a file in chunks, we allow several map tasks to operate on a single file in parallel. If the
file is very large, this can improve performance significantly through parallelism. Even more importantly, since the various blocks
that make up the file may be spread across several different nodes in the cluster, it allows tasks to be scheduled on each of these
different nodes; the individual blocks are thus all processed locally, instead of needing to be transferred from one node to another.
Of course, while log files can be processed in this piece-wise fashion, some file formats are not amenable to chunked processing.
By writing a custom InputFormat, you can control how the file is broken up (or is not broken up) into splits.

Question No : 4

You use the hadoop fs put command to write a 300 MB file using an HDFS block size of
64 MB. Just after this command has finished writing 200 MB of this file, what would another
user see when trying to access this file?

A. They would see no content until the whole file is written and closed.
B. They would see the content of the file through the last completed block.
C. They would see the current state of the file, up to the last bit written by the command.
D. They would see Hadoop throw an concurrentFileAccessException when they try to access this file.

Answer: A
Explanation: Note: *put Usage: hadoop fs -put <localsrc> ... <dst> Copy single src, or multiple srcs from local file system to the
destination filesystem. Also reads input from stdin and writes to destination filesystem.

Question No : 5

Does the MapReduce programming model provide a way for reducers to communicate with
each other?

A. Yes, all reducers can communicate with each other by passing information through the jobconf object.
B. Yes, reducers can communicate with each other by dispatching intermediate key value pairs that get shuffled to
another reduce
C. Yes, reducers running on the same machine can communicate with each other through shared memory, but not
reducers on different machines.
D. No, each reducer runs independently and in isolation.

Answer: D
Explanation: MapReduce programming model does not allow reducers to communicate with each other. Reducers run in isolation.
Reference:24 Interview Questions & Answers for Hadoop MapReduce developers http://www.fromdev.com/2010/12/interview-
questions-hadoop-mapreduce.html(See question no. 9)

Question No : 6

Which happens if the NameNode crashes?

A. HDFS becomes unavailable until the NameNode is restored.


B. The Secondary NameNode seamlessly takes over and there is no service interruption.
C. HDFS becomes unavailable to new MapReduce jobs, but running jobs will continue until completion.
D. HDFS becomes temporarily unavailable until an administrator starts redirecting client requests to the Secondary
NameNode.

Answer: A
Explanation: The NameNode is a Single Point of Failure for the HDFS Cluster. When the NameNode goes down, the file system
goes offline. Reference:24 Interview Questions & Answers for Hadoop MapReduce developers,What is a NameNode? How many
instances of NameNode run on a Hadoop Cluster?

Question No : 7

Combiners Increase the efficiency of a MapReduce program because:

A. They provide a mechanism for different mappers to communicate with each Other, thereby reducing synchronization
overhead.
https://www.exam-labs.com/exam/CCD-333 2/20
11/13/2019 CCD-333 Exam Tutorial

B. They provide an optimization and reduce the total number of computations that are needed to execute an algorithm
by a factor of n, where is the number of reducer.
C. They aggregate intermediate map output locally on each individual machine and therefore reduce the amount of data
that needs to be shuffled across the network to the reducers.
D. They aggregate intermediate map output horn a small number of nearby (i.e., rack-local) machines and therefore
reduce the amount of data that needs to be shuffled across the network to the reducers.

Answer: C
Explanation: Combiners are used to increase the efficiency of a MapReduce program. They are used to aggregate intermediate
map output locally on individual mapper outputs. Combiners can help you reduce the amount of data that needs to be transferred
across to the reducers. You can use your reducer code as a combiner if the operation performed is commutative and associative.
The execution of combiner is not guaranteed, Hadoop may or may not execute a combiner. Also, if required it may execute it
more then 1 times. Therefore your MapReduce jobs should not depend on the combiners execution. Reference:24 Interview
Questions & Answers for Hadoop MapReduce developers,What are combiners? When should I use a combiner in my MapReduce
Job? http://www.fromdev.com/2010/12/interview-questions-hadoop-mapreduce.html(question no. 12)

Question No : 8

You are developing a combiner that takes as input Text keys, IntWritable values, and emits
Text keys, Intwritable values. Which interface should your class implement?

A. Mapper <Text, IntWritable, Text, IntWritable>


B. Reducer <Text, Text, IntWritable, IntWritable>
C. Reducer <Text, IntWritable, Text, IntWritable>
D. Combiner <Text, IntWritable, Text, IntWritable>
E. Combiner <Text, Text, IntWritable, IntWritable>

Answer: D

Question No : 9

Workflows expressed in Oozie can contain:

A. Iterative repetition of MapReduce jobs until a desired answer or state is reached.


B. Sequences of MapReduce and Pig jobs. These are limited to linear sequences of actions with exception handlers but no
forks.
C. Sequences of MapReduce jobs only; no Pig or Hive tasks or jobs. These MapReduce sequences can be combined with
forks and path joins.
D. Sequences of MapReduce and Pig. These sequences can be combined with other actions including forks, decision
points, and path joins.

Answer: D
Reference:http://incubator.apache.org/oozie/docs/3.1.3/docs/WorkflowFunctionalSpec.html (workflow definition, first sentence)

Question No : 10

Given a Mapper, Reducer, and Driver class packaged into a jar, which is the correct way of
submitting the job to the cluster?

A. jar MyJar.jar
B. jar MyJar.jar MyDriverClass inputdir outputdir
C. hadoop jar MyJar.jar MyDriverClass inputdir outputdir
D. hadoop jar class MyJar.jar MyDriverClass inputdir outputdir

Answer: C
Explanation: Example: Run the application: $ bin/hadoop jar /usr/joe/wordcount.jar org.myorg.WordCount
/usr/joe/wordcount/input /usr/joe/wordcount/output

Question No : 11

https://www.exam-labs.com/exam/CCD-333 3/20
11/13/2019 CCD-333 Exam Tutorial

You have a large dataset of key-value pairs, where the keys are strings, and the values are
integers. For each unique key, you want to identify the largest integer. In writing a
MapReduce program to accomplish this, can you take advantage of a combiner?

A. No, a combiner would not be useful in this case.


B. Yes.
C. Yes, but the number of unique keys must be known in advance.
D. Yes, as long as all the keys fit into memory on each node.
E. Yes, as long as all the integer values that share the same key fit into memory on each node.

Answer: B

Question No : 12

In a large MapReduce job with m mappers and r reducers, how many distinct copy
operations will there be in the sort/shuffle phase?

A. m
B. r
C. m+r (i.e., m plus r)
D. mxr (i.e., m multiplied by r)
E. mr (i.e., m to the power of r)

Answer: D
Explanation: A MapReduce job withm mappers and r reducers involves up to m*r distinct copy operations, since eachmapper may
have intermediate output going to every reducer.

Question No : 13

You write a MapReduce job to process 100 files in HDFS. Your MapReduce algorithm uses
TextInputFormat and the IdentityReducer: the mapper applies a regular expression over
input values and emits key-value pairs with the key consisting of the matching text, and the
value containing the filename and byte offset. Determine the difference between setting the
number of reducers to zero.

A. There is no difference in output between the two settings.


B. With zero reducers, no reducer runs and the job throws an exception. With one reducer, instances of matching
patterns are stored in a single file on HDFS.
C. With zero reducers, all instances of matching patterns are gathered together in one file on HDFS. With one reducer,
instances of matching patterns stored in multiple files on HDFS.
D. With zero reducers, instances of matching patterns are stored in multiple files on HDFS. With one reducer, all
instances of matching patterns are gathered together in one file on HDFS.

Answer: D
Explanation: *It is legal to set the number of reduce-tasks to zero if no reduction is desired. In this case the outputs of the map-
tasks go directly to the FileSystem, into the output path set by setOutputPath(Path). The framework does not sort the map-
outputs before writing them out to the FileSystem. *Often, you may want to process input data using a map function only. To do
this, simply set mapreduce.job.reduces to zero. The MapReduce framework will not create any reducer tasks. Rather, the outputs
of the mapper tasks will be the final output of the job. Note: Reduce In this phase the reduce(WritableComparable, Iterator,
OutputCollector, Reporter) method is called for each <key, (list of values)> pair in the grouped inputs. The output of the reduce
task is typically written to the FileSystem via OutputCollector.collect(WritableComparable, Writable). Applications can use the
Reporter to report progress, set application-level status messages and update Counters, or just indicate that they are alive. The
output of the Reducer is not sorted.

Question No : 14

Which of the following best describes the map method input and output?

A. It accepts a single key-value pair as input and can emit only one key-value pair as output.
B. It accepts a list of key-value pairs as input hut run emit only one key value pair as output.

https://www.exam-labs.com/exam/CCD-333 4/20
11/13/2019 CCD-333 Exam Tutorial

C. It accepts a single key-value pair as input and emits a single key and list of corresponding values as output
D. It accepts a single key-value pair as input and can emit any number of key-value pairs as output, including zero.

Answer: D
Explanation: public class Mapper<KEYIN,VALUEIN,KEYOUT,VALUEOUT> extends Object Maps input key/value pairs to a set of
intermediate key/value pairs. Maps are the individual tasks which transform input records into a intermediate records. The
transformed intermediate records need not be of the same type as the input records. A given input pair may map to zero or many
output pairs. Reference: org.apache.hadoop.mapreduce Class Mapper<KEYIN,VALUEIN,KEYOUT,VALUEOUT>

Question No : 15

Which two of the following are valid statements? (Choose two)

A. HDFS is optimized for storing a large number of files smaller than the HDFS block size.
B. HDFS has the Characteristic of supporting a "write once, read many" data access model.
C. HDFS is a distributed file system that replaces ext3 or ext4 on Linux nodes in a Hadoop cluster.
D. HDFS is a distributed file system that runs on top of native OS filesystems and is well suited to storage of very large
data sets.

Answer: B,D
Explanation: B:HDFS is designed to support very large files. Applications that are compatible with HDFS are those that deal with
large data sets. These applications write their data only once but they read it one or more times and require these reads to be
satisfied at streaming speeds. HDFS supports write-once-read-many semantics on files. D: *Hadoop Distributed File System: A
distributed file system that provides high-throughput access to application data. *DFS is designed to support very large files.
Reference:24 Interview Questions & Answers for Hadoop MapReduce developers

Question No : 16

You are running a job that will process a single InputSplit on a cluster which has no other
jobs currently running. Each node has an equal number of open Map slots. On which node
will Hadoop first attempt to run the Map task?

A. The node with the most memory


B. The node with the lowest system load
C. The node on which this InputSplit is stored
D. The node with the most free local disk space

Answer: C
Explanation: The TaskTrackers send out heartbeat messages to the JobTracker, usually every few minutes, to reassure the
JobTracker that it is still alive. These message also inform the JobTracker of the number of available slots, so the JobTracker can
stay up to date with where in the cluster work can be delegated. When the JobTracker tries to find somewhere to schedule a task
within the MapReduce operations, it first looks for an empty slot on the same server that hosts the DataNode containing the data,
and if not, it looks for an empty slot on a machine in the same rack.

Question No : 17

MapReduce is well-suited for all of the following applications EXCEPT? (Choose one):

A. Text mining on a large collections of unstructured documents.


B. Analysis of large amounts of Web logs (queries, clicks, etc.).
C. Online transaction processing (OLTP) for an e-commerce Website.
D. Graph mining on a large social network (e.g., Facebook friends network).

Answer: C
Explanation: Hadoop Map/Reduce is designed for batch-oriented work load. MapReduce is well suited for data warehousing
(OLAP), but not for OLTP.

Question No : 18

In a MapReduce job with 500 map tasks, how many map task attempts will there be?

https://www.exam-labs.com/exam/CCD-333 5/20
11/13/2019 CCD-333 Exam Tutorial

A. At least 500.
B. Exactly 500.
C. At most 500.
D. Between 500 and 1000.
E. It depends on the number of reducers in the job.

Answer: A
Explanation: From Cloudera Training Course: Task attempt is a particular instance of an attempt to execute a task There will be at
least as many task attempts as there are tasks If a task attempt fails, another will be started by the JobTracker Speculative
execution can also result in more task attempts than completed tasks

Question No : 19

What happens in a MapReduce job when you set the number of reducers to zero?

A. No reducer executes, but the mappers generate no output.


B. No reducer executes, and the output of each mapper is written to a separate file in HDFS.
C. No reducer executes, but the outputs of all the mappers are gathered together and written to a single file in HDFS.
D. Setting the number of reducers to zero is invalid, and an exception is thrown.

Answer: B
Explanation: *It is legal to set the number of reduce-tasks to zero if no reduction is desired. In this case the outputs of the map-
tasks go directly to the FileSystem, into the output path set by setOutputPath(Path). The framework does not sort the map-
outputs before writing them out to the FileSystem. *Often, you may want to process input data using a map function only. To do
this, simply set mapreduce.job.reduces to zero. The MapReduce framework will not create any reducer tasks. Rather, the outputs
of the mapper tasks will be the final output of the job.

Question No : 20

For each intermediate key, each reducer task can emit:

A. One final key value pair per key; no restrictions on the type.
B. One final key-value pair per value associated with the key; no restrictions on the type.
C. As many final key-value pairs as desired, as long as all the keys have the same type and all the values have the same
type.
D. As many final key-value pairs as desired, but they must have the same type as the intermediate key-value pairs.
E. As many final key value pairs as desired. There are no restrictions on the types of those key-value pairs (i.e., they can
be heterogeneous)

Answer: A
Explanation: Reducer reduces a set of intermediate values which share a key to a smaller set of values. Reference:Hadoop Map-
Reduce Tutorial

Question No : 21

What types of algorithms are difficult to express MapReduce?

A. Algorithms that requite global, shared state.


B. Large-scale graph algorithms that require one-step link traversal.
C. Relational operations on large amounts of structured and semi structured data.
D. Text analysis algorithms on large collections of unstructured text (e.g., Web crawls).
E. Algorithms that require applying the same mathematical function to large numbers of individual binary records.

Answer: A
Explanation: See 3) below. Limitations of Mapreducewhere not to use Mapreduce While very powerful and applicable to a wide
variety of problems, MapReduce is not the answer to every problem. Here are some problems I found where MapReudce is not
suited and some papers that address the limitations of MapReuce. 1. Computation depends on previously computed values If the
computation of a value depends on previously computed values, then MapReduce cannot be used. One good example is the
Fibonacci series where each value is summation of the previous two values. i.e., f(k+2) = f(k+1) + f(k). Also, if the data set is
small enough to be computed on a single machine, then it is better to do it as a single reduce(map(data)) operation rather than
going through the entire map reduce process. 2. Full-text indexing or ad hoc searching The index generated in the Map step is

https://www.exam-labs.com/exam/CCD-333 6/20
11/13/2019 CCD-333 Exam Tutorial
one dimensional, and the Reduce step must not generate a large amount of data or there will be a serious performance
degradation. For example, CouchDBs MapReduce may not be a good fit for full-text indexing or ad hoc searching. This is a
problem better suited for a tool such as Lucene. 3. Algorithms depend on shared global state Solutions to many interesting
problems in text processing do not require global synchronization.As a result, they can be expressed naturally in MapReduce,
since map and reduce tasks run independently and in isolation. However, there are many examples of algorithms that depend
crucially on the existence of shared global state during processing, making them difficult to implement in MapReduce (since the
single opportunity for global synchronization in MapReduce is the barrier between the map and reduce phases of processing)
Reference: Limitations of Mapreducewhere not to use Mapreduce

Question No : 22

You need to create a GUI application to help your company's sales people add and edit
customer information. Would HDFS be appropriate for this customer information file?

A. Yes, because HDFS is optimized for random access writes.


B. Yes, because HDFS is optimized for fast retrieval of relatively small amounts of data.
C. No, because HDFS can only be accessed by MapReduce applications.
D. No, because HDFS is optimized for write-once, streaming access for relatively large files.

Answer: D
Explanation: HDFS is designed to support very large files. Applications that are compatible with HDFS are those that deal with
large data sets. These applications write their data only once but they read it one or more times and require these reads to be
satisfied at streaming speeds. HDFS supports write-once-read-many semantics on files. Reference:24 Interview Questions &
Answers for Hadoop MapReduce developers,What is HDFS ? How it is different from traditional file systems?

Question No : 23

Given a directory of files with the following structure: line number, tab character, string:
Example:
1. abialkjfjkaoasdfjksdlkjhqweroij
2. kadf jhuwqounahagtnbvaswslmnbfgy
3. kjfteiomndscxeqalkzhtopedkfslkj
You want to send each line as one record to your Mapper. Which InputFormat would you
use to complete the line: setInputFormat (________.class);

A. BDBInputFormat
B. KeyValueTextInputFormat
C. SequenceFileInputFormat
D. SequenceFileAsTextInputFormat

Answer: C
Explanation: Note: The output format for your first MR job should be SequenceFileOutputFormat - this will store the Key/Values
output from the reducer in a binary format, that can then be read back in, in your second MR job using SequenceFileInputFormat.
Reference:http://stackoverflow.com/questions/9721754/how-to-parse-customwritable-from- text-in-hadoop(see answer 1 and
then see the comment #1 for it)

Question No : 24

Which statement best describes the data path of intermediate key-value pairs (i.e., output
of the mappers)?

A. Intermediate key-value pairs are written to HDFS. Reducers read the intermediate data from HDFS.
B. Intermediate key-value pairs are written to HDFS. Reducers copy the intermediate data to the local disks of the
machines running the reduce tasks.
C. Intermediate key-value pairs are written to the local disks of the machines running the map tasks, and then copied to
the machine running the reduce tasks.
D. Intermediate key-value pairs are written to the local disks of the machines running the map tasks, and are then
copied to HDFS. Reducers read the intermediate data from HDFS.

Answer: C
Explanation: The mapper output (intermediate data) is stored on the Local file system (NOT HDFS) of each individual mapper

https://www.exam-labs.com/exam/CCD-333 7/20
11/13/2019 CCD-333 Exam Tutorial
nodes. This is typically a temporary directory location which can be setup in config by the hadoop administrator. The intermediate
data is cleaned up after the Hadoop Job completes. Note: *Reducers start copying intermediate key-value pairs from the mappers
as soon as they are available. The progress calculation also takes in account the processing of data transfer which is done by
reduce process, therefore the reduce progress starts showing up as soon as any intermediate key-value pair for a mapper is
available to be transferred to reducer. Though the reducer progress is updated still the programmer defined reduce method is
called only after all the mappers have finished. *Reducer is input the grouped output of a Mapper. In the phase the framework,
for each Reducer, fetches the relevant partition of the output of all the Mappers, via HTTP. *Mapper maps input key/value pairs to
a set of intermediate key/value pairs. Maps are the individual tasks that transform input records into intermediate records. The
transformed intermediate records do not need to be of the same type as the input records. A given input pair may map to zero or
many output pairs. *All intermediate values associated with a given output key are subsequently grouped by the framework, and
passed to the Reducer(s) to determine the final output. Reference:Questions & Answers for Hadoop MapReduce developers,Where
is the Mapper Output (intermediate kay-value data) stored ?

Question No : 25

All keys used for intermediate output from mappers must do which of the following:

A. Override isSplitable
B. Implement WritableComparable
C. Be a subclass of Filelnput-Format
D. Use a comparator for speedy sorting
E. Be compressed using a splittable compression algorithm.

Answer: B
Explanation: The MapReduce framework operates exclusively on <key, value> pairs, that is, the framework views the input to the
job as a set of <key, value> pairs and produces a set of <key, value> pairs as the output of the job, conceivably of different
types. The key and value classes have to be serializable by the framework and hence need to implement the Writable interface.
Additionally, the key classes have to implement the WritableComparable interface to facilitate sorting by the framework.
Reference:MapReduce Tutorial

Question No : 26

You have the following key value pairs as output from your Map task:
(The, 1)
(Fox, 1)
(Runs, 1)
(Faster, 1)
(Than, 1)
(The, 1)
(Dog, 1)
How many keys will be passed to the reducer?

A. One
B. Two
C. Three
D. Four
E. Five
F. Six

Answer: F
Explanation: Only one key value pair will be passed from thetwo(The, 1) key value pairs.

Question No : 27

You've written a MapReduce job that will process 500 million input records and generate
500 million key-value pairs. The data is not uniformly distributed. Your MapReduce job will
create a significant amount of intermediate data that it needs to transfer between mappers
and reducers which is a potential bottleneck. A custom implementation of which of the
following interfaces is most likely to reduce the amount of intermediate data transferred
across the network?

https://www.exam-labs.com/exam/CCD-333 8/20
11/13/2019 CCD-333 Exam Tutorial

A. Writable
B. WritableComparable
C. InputFormat
D. OutputFormat
E. Combiner
F. Partitioner

Answer: E
Explanation: Users can optionally specify a combiner, via JobConf.setCombinerClass(Class), to perform local aggregation of the
intermediate outputs, which helps to cut down the amount of data transferred from the Mapper to the Reducer.
Reference:Map/Reduce Tutorial http://hadoop.apache.org/common/docs/r0.20.2/mapred_tutorial.html(Mapper, 9th paragraph)

Question No : 28

What is a Writable?

A. Writable is an interface that all keys and values in MapReduce must implement. Classes implementing this interface
must implement methods for serializing and deserializing themselves.
B. Writable is an abstract class that all keys and values in MapReduce must extend. Classes extending this abstract base
class must implement methods for serializing and deserializing themselves
C. Writable is an interface that all keys, but not values, in MapReduce must implement. Classes implementing this
interface must implement methods for serializing and deserializing themselves.
D. Writable is an abstract class that all keys, but not values, in MapReduce must extend. Classes extending this abstract
base class must implement methods for serializing and deserializing themselves.

Answer: A
Explanation: public interface Writable A serializable object which implements a simple, efficient, serialization protocol, based on
DataInput and DataOutput. Any key or value type in the Hadoop Map-Reduce framework implements this interface.
Implementations typically implement a static read(DataInput) method which constructs a new instance, calls
readFields(DataInput) and returns the instance. Reference: org.apache.hadoop.io,Interface Writable

Question No : 29

In a MapReduce job, the reducer receives all values associated with the same key. Which
statement is most accurate about the ordering of these values?

A. The values are in sorted order.


B. The values are arbitrarily ordered, and the ordering may vary from run to run of the same MapReduce job.
C. The values are arbitrarily ordered, but multiple runs of the same MapReduce job will always have the same ordering.
D. Since the values come from mapper outputs, the reducers will receive contiguous sections of sorted values.

Answer: D
Explanation: Note: *The Mapper outputs are sorted and then partitioned per Reducer. *The intermediate, sorted outputs are
always stored in a simple (key-len, key, value-len, value) format. *Input to the Reducer is the sorted output of the mappers. In
this phase the framework fetches the relevant partition of the output of all the mappers, via HTTP. *A MapReduce job usually
splits the input data-set into independent chunks which are processed by the map tasks in a completely parallel manner. The
framework sorts the outputs of the maps, which are then input to the reduce tasks. *The MapReduce framework operates
exclusively on <key, value> pairs, that is, the framework views the input to the job as a set of <key, value> pairs and produces a
set of <key, value> pairs as the output of the job, conceivably of different types. The key and value classes have to be
serializable by the framework and hence need to implement the Writable interface. Additionally, the key classes have to
implement the WritableComparable interface to facilitate sorting by the framework. Reference:MapReduce Tutorial

Question No : 30

Your Custers HOFS block size is 64MB. You have a directory containing 100 plain text
files, each of which Is 100MB in size. The InputFormat for your job is TextInputFormat.
How many Mappers will run?

A. 64
B. 100

https://www.exam-labs.com/exam/CCD-333 9/20
11/13/2019 CCD-333 Exam Tutorial

C. 200
D. 640

Answer: C
Explanation: Each file would be split into two as the block size (64 MB) is less than the file size (100 MB), so 200 mappers would
be running. Note: If you're not compressing the files then hadoop will process your large files (say 10G), with a number of
mappers related to the block size of the file. Say your block size is 64M, then you will have ~160 mappers processing this 10G file
(160*64 ~= 10G). Depending on how CPU intensive your mapper logic is, this might be an acceptable blocks size, but if you find
that your mappers are executing in sub minute times, then you might want to increase the work done by each mapper (by
increasing the block size to 128, 256, 512m - the actual size depends on how you intend to process the data).
Reference:http://stackoverflow.com/questions/11014493/hadoop-mapreduce-appropriate- input-files-size(first answer, second
paragraph)

Question No : 31

What is the standard configuration of slave nodes in a Hadoop cluster?

A. Each slave node runs a JobTracker and a DataNode daemon.


B. Each slave node runs a TaskTracker and a DataNode daemon.
C. Each slave node either runs a TaskTracker or a DataNode daemon, but not both.
D. Each slave node runs a DataNode daemon, but only a fraction of the slave nodes run TaskTrackers.
E. Each slave node runs a TaskTracker, but only a fraction of the slave nodes run DataNode daemons.

Answer: B
Explanation: Single instance of a Task Tracker is run on each Slave node. Task tracker is run as a separate JVM process. Single
instance of a DataNode daemon is run on each Slave node. DataNode daemon is run as a separate JVM process. One or Multiple
instances of Task Instance is run on each slave node. Each task instance is run as a separate JVM process. The number of Task
instances can be controlled by configuration. Typically a high end machine is configured to run more task instances. Reference:24
Interview Questions & Answers for Hadoop MapReduce developers,What is configuration of a typical slave node on Hadoop
cluster? How many JVMs run on a slave node?

Question No : 32

You need to create a job that does frequency analysis on input data. You will do this by
writing a Mapper that uses TextInputForma and splits each value (a line of text from an
input file) into individual characters. For each one of these characters, you will emit the
character as a key and as IntWritable as the value. Since this will produce proportionally
more intermediate data than input data, which resources could you expect to be likely
bottlenecks?

A. Processor and RAM


B. Processor and disk I/O
C. Disk I/O and network I/O
D. Processor and network I/O

Answer: B

Question No : 33

Your client application submits a MapReduce job to your Hadoop cluster. The Hadoop
framework looks for an available slot to schedule the MapReduce operations on which of
the following Hadoop computing daemons?

A. DataNode
B. NameNode
C. JobTracker
D. TaskTracker
E. Secondary NameNode

Answer: C
Explanation: JobTracker is the daemon service for submitting and tracking MapReduce jobs in Hadoop. There is only One Job
https://www.exam-labs.com/exam/CCD-333 10/20
11/13/2019 CCD-333 Exam Tutorial
Tracker process run on any hadoop cluster. Job Tracker runs on its own JVM process. In a typical production cluster its run on a
separate machine. Each slave node is configured with job tracker node location. The JobTracker is single point of failure for the
Hadoop MapReduce service. If it goes down, all running jobs are halted. JobTracker in Hadoop performs following actions(from
Hadoop Wiki:) Client applications submit jobs to the Job tracker. The JobTracker talks to the NameNode to determine the location
of the data The JobTracker locates TaskTracker nodes with available slots at or near the data The JobTracker submits the work to
the chosen TaskTracker nodes. The TaskTracker nodes are monitored. If they do not submit heartbeat signals often enough, they
are deemed to have failed and the work is scheduled on a different TaskTracker. A TaskTracker will notify the JobTracker when a
task fails. The JobTracker decides what to do then: it may resubmit the job elsewhere, it may mark that specific record as
something to avoid, and it may may even blacklist the TaskTracker as unreliable. When the work is completed, the JobTracker
updates its status. Client applications can poll the JobTracker for information. Reference:24 Interview Questions & Answers for
Hadoop MapReduce developers,What is a JobTracker in Hadoop? How many instances of JobTracker run on a Hadoop Cluster?

Question No : 34

How does the NameNode detect that a DataNode has failed?

A. The NameNode does not need to know that a DataNode has failed.
B. When the NameNode fails to receive periodic heartbeats from the DataNode, it considers the DataNode as failed.
C. The NameNode periodically pings the datanode. If the DataNode does not respond, the NameNode considers the
DataNode as failed.
D. When HDFS starts up, the NameNode tries to communicate with the DataNode and considers the DataNode as failed if
it does not respond.

Answer: B
Explanation: NameNode periodically receives a Heartbeat and a Blockreport from each of the DataNodes in the cluster. Receipt of
a Heartbeat implies that the DataNode is functioning properly. A Blockreport contains a list of all blocks on a DataNode. When
NameNode notices that it has not recieved a hearbeat message from a data node after a certain amount of time, the data node is
marked as dead. Since blocks will be under replicated the system begins replicating the blocks that were stored on the dead
datanode. The NameNode Orchestrates the replication of data blocks from one datanode to another. The replication data transfer
happens directly between datanodes and the data never passes through the namenode. Reference:24 Interview Questions &
Answers for Hadoop MapReduce developers,How NameNode Handles data node failures?

Question No : 35

You need to import a portion of a relational database every day as files to HDFS, and
generate Java classes to Interact with your imported data. Which of the following tools
should you use to accomplish this?

A. Pig
B. Hue
C. Hive
D. Flume
E. Sqoop
F. Oozie
G. fuse-dfs

Answer: E
Explanation: Sqoop (SQL-to-Hadoop) is a straightforward command-line tool with the following capabilities: Imports individual
tables or entire databases to files in HDFS Generates Java classes to allow you to interact with your imported data Provides the
ability to import from SQL databases straight into your Hive data warehouse Note: Data Movement Between Hadoop and
Relational Databases Data can be moved between Hadoop and a relational database as a bulk data transfer, or relational tables
can be accessed from within a MapReduce map function. Note: *Cloudera's Distribution for Hadoop provides a bulk data transfer
tool (i.e., Sqoop) that imports individual tables or entire databases into HDFS files. The tool also generates Java classes that
support interaction with the imported data. Sqoop supports all relational databases over JDBC, and Quest Software provides a
connector (i.e., OraOop) that has been optimized for access to data residing in Oracle databases.
Reference:http://log.medcl.net/item/2011/08/hadoop-and-mapreduce-big-data-analytics- gartner/(Data Movement between
hadoop and relational databases, second paragraph)

Question No : 36

Which of the following describes how a client reads a file from HDFS?

https://www.exam-labs.com/exam/CCD-333 11/20
11/13/2019 CCD-333 Exam Tutorial

A. The client queries the NameNode for the block location(s). The NameNode returns the block location(s) to the client.
The client reads the data directly off the DataNode(s).
B. The client queries all DataNodes in parallel. The DataNode that contains the requested data responds directly to the
client. The client reads the data directly off the DataNode.
C. The client contacts the NameNode for the block location(s). The NameNode then queries the DataNodes for block
locations. The DataNodes respond to the NameNode, and the NameNode redirects the client to the DataNode that holds
the requested data block(s). The client then reads the data directly off the DataNode.
D. The client contacts the NameNode for the block location(s). The NameNode contacts theDataNode that holds the
requested data block. Data is transferred from the DataNode to the NameNode, and then from the NameNode to the
client.

Answer: C
Explanation: The Client communication to HDFS happens using Hadoop HDFS API. Client applications talk to the NameNode
whenever they wish to locate a file, or when they want to add/copy/move/delete a file on HDFS. The NameNode responds the
successful requests by returning a list of relevant DataNode servers where the data lives. Client applications can talk directly to a
DataNode, once the NameNode has provided the location of the data. Reference: 24 Interview Questions & Answers for Hadoop
MapReduce developers,How the Client communicates with HDFS?

Question No : 37

What is the preferred way to pass a small number of configuration parameters to a mapper
or reducer?

A. As key-value pairs in the jobconf object.


B. As a custom input key-value pair passed to each mapper or reducer.
C. Using a plain text file via the Distributedcache, which each mapper or reducer reads.
D. Through a static variable in the MapReduce driver class (i.e., the class that submits the MapReduce job).

Answer: A
Explanation: In Hadoop, it is sometimes difficult to pass arguments to mappers and reducers. If the number of arguments is huge
(e.g., big arrays), DistributedCache might be a good choice. However, here, were discussing small arguments, usually a hand of
configuration parameters. In fact, the way to configure these parameters is simple. When you initializeJobConfobject to launch a
mapreduce job, you can set the parameter by usingsetmethod like: 1JobConf job = (JobConf)getConf();
2job.set("NumberOfDocuments", args[0]); Here,NumberOfDocumentsis the name of parameter and its value is read fromargs[0],
a command line argument. Reference:Passing Parameters and Arguments to Mapper and Reducer in Hadoop

Question No : 38

Which of the following statements most accurately describes the relationship between
MapReduce and Pig?

A. Pig provides additional capabilities that allow certain types of data manipulation not possible with MapReduce.
B. Pig provides no additional capabilities to MapReduce. Pig programs are executed as MapReduce jobs via the Pig
interpreter.
C. Pig programs rely on MapReduce but are extensible, allowing developers to do special- purpose processing not
provided by MapReduce.
D. Pig provides the additional capability of allowing you to control the flow of multiple MapReduce jobs.

Answer: D
Explanation: In addition to providing many relational and data flow operators Pig Latin provides ways for you to control how your
jobs execute on MapReduce. It allows you to set values that control your environment and to control details of MapReduce such
as how your data is partitioned. Reference:http://ofps.oreilly.com/titles/9781449302641/advanced_pig_latin.html(topic:
controlling execution)

Question No : 39

To process input key-value pairs, your mapper needs to load a 512 MB data file in memory.
What is the best way to accomplish this?

A. Place the datafile in the DataCache and read the data into memory in the configure method ofthe mapper.
B. Place the data file in theDistributedCacheand read the data into memory in the map method of the mapper.
https://www.exam-labs.com/exam/CCD-333 12/20
11/13/2019 CCD-333 Exam Tutorial

C. Place the data file in theDistributedCacheand read the data into memory in the configure method of the mapper.
D. Serialize the data file, insert it in the Jobconf object, and read the data into memory in the configure method of the
mapper.

Answer: B
Explanation: Hadoop has a distributed cache mechanism to make available file locally that may be needed by Map/Reduce jobs
Use Case Lets understand our Use Case a bit more in details so that we can follow-up the code snippets. We have a Key-Value file
that we need to use in our Map jobs. For simplicity, lets say we need to replace all keywords that we encounter during parsing,
with some other value. So what we need is A key-values files (Lets use a Properties files) The Mapper code that uses the code
Write the Mapper code that uses it view sourceprint? 01. public class DistributedCacheMapper extends Mapper<LongWritable,
Text, Text, Text> { 02. 03. Properties cache; 04. 05. @Override 06. protected void setup(Context context) throws IOException,
InterruptedException { 07. super.setup(context); 08. Path[] localCacheFiles =
DistributedCache.getLocalCacheFiles(context.getConfiguration()); 09. 10. if(localCacheFiles != null) { 11. // expecting only single
file here 12. for (int i = 0; i < localCacheFiles.length; i++) { 13. Path localCacheFile = localCacheFiles[i]; 14. cache = new
Properties(); 15. cache.load(new FileReader(localCacheFile.toString())); 16. } 17. } else { 18. // do your error handling here 19.
} 20. 21. } 22. 23. @Override 24. public void map(LongWritable key, Text value, Context context) throws IOException,
InterruptedException { 25. // use the cache here 26. // if value contains some attribute, cache.get(<value>) 27. // do some
action or replace with something else 28. } 29. 30. } Note: * Distribute application-specific large, read-only files efficiently.
DistributedCache is a facility provided by the Map-Reduce framework to cache files (text, archives, jars etc.) needed by
applications. Applications specify the files, via urls (hdfs:// or http://) to be cached via the JobConf. The DistributedCache
assumes that the files specified via hdfs:// urls are already present on the FileSystem at the path specified by the url.
Reference:Using Hadoop Distr

Question No : 40

You need a distributed, scalable, data Store that allows you random, realtime read/write
access to hundreds of terabytes of data. Which of the following would you use?

A. Hue
B. Pig
C. Hive
D. Oozie
E. HBase
F. Flume
G. Sqoop

Answer: E
Explanation: Use Apache HBase when you need random, realtime read/write access to your Big Data. Note:This project's goal is
the hosting of very large tables -- billions of rows X millions of columns -- atop clusters of commodity hardware. Apache HBase is
an open-source, distributed, versioned, column-oriented store modeled after Google's Bigtable: A Distributed Storage System for
Structured Data by Chang et al. Just as Bigtable leverages the distributed data storage provided by the Google File System,
Apache HBase provides Bigtable-like capabilities on top of Hadoop and HDFS. Features Linear and modular scalability. Strictly
consistent reads and writes. Automatic and configurable sharding of tables Automatic failover support between RegionServers.
Convenient base classes for backing Hadoop MapReduce jobs with Apache HBase tables. Easy to use Java API for client access.
Block cache and Bloom Filters for real-time queries. Query predicate push down via server side Filters Thrift gateway and a REST-
ful Web service that supports XML, Protobuf, and binary data encoding options Extensible jruby-based (JIRB) shell Support for
exporting metrics via the Hadoop metrics subsystem to files or Ganglia; or via JMX Reference:http://hbase.apache.org/(when
would I use HBase? First sentence)

Question No : 41

During the standard sort and shuffle phase of MapReduce, keys and values are passed to
reducers. Which of the following is true?

A. Keys are presented to a reducer in sorted order; values for a given key are not sorted.
B. Keys are presented to a reducer in soiled order; values for a given key are sorted in ascending order.
C. Keys are presented to a reducer in random order; values for a given key are not sorted.
D. Keys are presented to a reducer in random order; values for a given key are sorted in ascending order.

Answer: D

Question No : 42

https://www.exam-labs.com/exam/CCD-333 13/20
11/13/2019 CCD-333 Exam Tutorial

You have written a Mapper which invokes the following five calls to the
outputcollector.collect method:
C:\Documents and Settings\RraAsShHiIdD\Desktop\untitled.JPG
How many times will the Reducer's reduce method be invoked.

A. 0
B. 1
C. 3
D. 5
E. 6

Answer: C
Explanation: Note: org.apache.hadoop.mapred Interface OutputCollector<K,V> Collects the <key, value> pairs output by
Mappers and Reducers. OutputCollector is the generalization of the facility provided by the Map-Reduce framework to collect data
output by either the Mapper or the Reducer i.e. intermediate outputs or the output of the job.

Question No : 43

For each input key-value pair, mappers can emit:

A. One intermediate key value pair, of a different type.


B. One intermediate key value pair, but of the same type.
C. As many intermediate key-value pairs as desired, but they cannot be of the same type as the input key-value pair.
D. As many intermediate key value pairs as desired, as long as all the keys have the same type and all the values have
the same type.
E. As many intermediate key-value pairs as desired. There are no restrictions on the types of those key-value pairs (i.e.,
they can be heterogeneous).

Answer: E
Explanation: Mapper maps input key/value pairs to a set of intermediate key/value pairs. Maps are the individual tasks that
transform input records into intermediate records. The transformed intermediate records do not need to be of the same type as
the input records. A giveninput pair may map to zero or many output pairs. Reference: Hadoop Map-Reduce Tutorial

Question No : 44

Your cluster has 10 DataNodes, each with a single 1 TB hard drive. You utilize all your disk
capacity for HDFS, reserving none for MapReduce. You implement default replication
settings. What is the storage capacity of your Hadoop cluster (assuming no compression)?

A. about 3 TB
B. about 5 TB
C. about 10 TB
D. about 11 TB

Answer: A
Explanation: In default configuration there are total 3 copies of a datablock on HDFS, 2 copies are stored on datanodes on same
rack and 3rd copy on a different rack. Note:HDFS is designed to reliably store very large files across machines in a large cluster.
It stores each file as a sequence of blocks; all blocks in a file except the last block are the same size. The blocks of a file are
replicated for fault tolerance. The block size and replication factor are configurable per file. An application can specify the number
of replicas of a file. The replication factor can be specified at file creation time and can be changed later. Files in HDFS are write-
once and have strictly one writer at any time. The NameNode makes all decisions regarding replication of blocks. HDFS uses rack-
aware replica placement policy. Reference:24 Interview Questions & Answers for Hadoop MapReduce developers,How the HDFS
Blocks are replicated?

Question No : 45

Which of the Following best describes the lifecycle of a Mapper?

A. The TaskTracker spawns a new Mapper to process each key-value pair.


B. The JobTracker spawns a new Mapper to process all records in a single file.

https://www.exam-labs.com/exam/CCD-333 14/20
11/13/2019 CCD-333 Exam Tutorial

C. The TaskTracker spawns a new Mapper to process all records in a single input split.
D. The JobTracker calls the FastTracker's configure () method, then its map () method and finally its closer ()

Answer: A
Explanation: For each map instance that runs, the TaskTracker creates a new instance of your mapper. Note: *The Mapper is
responsible for processing Key/Value pairs obtained from the InputFormat. The mapper may perform a number of Extraction and
Transformation functions on the Key/Value pair before ultimately outputting none, one or many Key/Value pairs of the same, or
different Key/Value type. *With the new Hadoop API, mappers extend the org.apache.hadoop.mapreduce.Mapper class. This class
defines an 'Identity' map function by default - every input Key/Value pair obtained from the InputFormat is written out. Examining
the run() method, we can see the lifecycle of the mapper: /** * Expert users can override this method for more complete control
over the * execution of the Mapper. * @param context * @throws IOException */ public void run(Context context) throws
IOException, InterruptedException { setup(context); while (context.nextKeyValue()) { map(context.getCurrentKey(),
context.getCurrentValue(), context); } cleanup(context); } setup(Context) - Perform any setup for the mapper. The default
implementation is a no-op method. map(Key, Value, Context) - Perform a map operation in the given Key / Value pair. The default
implementation calls Context.write(Key, Value) cleanup(Context) - Perform any cleanup for the mapper. The default
implementation is a no-op method. Reference:Hadoop/MapReduce/Mapper

Question No : 46

Which of the following utilities allows you to create and run MapReduce jobs with any
executable or script as the mapper and/or the reducer?

A. Oozie
B. Sqoop
C. Flume
D. Hadoop Streaming

Answer: D
Explanation: Hadoop streaming is a utility that comes with the Hadoop distribution. The utility allows you to create and run
Map/Reduce jobs with any executable or script as the mapper and/or the reducer.
Reference:http://hadoop.apache.org/common/docs/r0.20.1/streaming.html(Hadoop Streaming,second sentence)

Question No : 47

The Hadoop framework provides a mechanism for coping with machine issues such as
faulty configuration or impending hardware failure. MapReduce detects that one or a
number of machines are performing poorly and starts more copies of a map or reduce task.
All the tasks run simultaneously and the task that finish first are used. This is called:

A. Combiner
B. IdentityMapper
C. IdentityReducer
D. Default Partitioner
E. Speculative Execution

Answer: E
Explanation: Speculative execution: One problem with the Hadoop system is that by dividing the tasks across many nodes, it is
possible for a few slow nodes to rate-limit the rest of the program. For example if one node has a slow disk controller, then it may
be reading its input at only 10% the speed of all the other nodes. So when 99 map tasks are already complete, the system is still
waiting for the final map task to check in, which takes much longer than all the other nodes. By forcing tasks to run in isolation
from one another, individual tasks do not know where their inputs come from. Tasks trust the Hadoop platform to just deliver the
appropriate input. Therefore, the same input can be processed multiple times in parallel, to exploit differences in machine
capabilities. As most of the tasks in a job are coming to a close, the Hadoop platform will schedule redundant copies of the
remaining tasks across several nodes which do not have other work to perform. This process is known as speculative execution.
When tasks complete, they announce this fact to the JobTracker. Whichever copy of a task finishes first becomes the definitive
copy. If other copies were executing speculatively, Hadoop tells the TaskTrackers to abandon the tasks and discard their outputs.
The Reducers then receive their inputs from whichever Mapper completed successfully, first. Reference:Apache Hadoop,Module 4:
MapReduce

Question No : 48

What happens in a MapReduce job when you set the number of reducers to one?

https://www.exam-labs.com/exam/CCD-333 15/20
11/13/2019 CCD-333 Exam Tutorial

A. A single reducer gathers and processes all the output from all the mappers. The output is written in as many separate
files as there are mappers.
B. A single reducer gathers and processes all the output from all the mappers. The output is written to a single file in
HDFS.
C. Setting the number of reducers to one creates a processing bottleneck, and since the number of reducers as specified
by the programmer is used as a reference value only, the MapReduce runtime provides a default setting for the number
of reducers.
D. Setting the number of reducers to one is invalid, and an exception is thrown.

Answer: A
Explanation: *It is legal to set the number of reduce-tasks to zero if no reduction is desired. In this case the outputs of the map-
tasks go directly to the FileSystem, into the output path set bysetOutputPath(Path). The framework does not sort the map-
outputs before writing them out to the FileSystem. *Often, you may want to process input data using a map function only. To do
this, simply set mapreduce.job.reduces to zero. The MapReduce framework will not create any reducer tasks. Rather, the outputs
of the mapper tasks will be the final output of the job.

Question No : 49

In the reducer, the MapReduce API provides you with an iterator over Writable values.
Calling the next () method:

A. Returns a reference to a different Writable object each time.


B. Returns a reference to a Writable object from an object pool.
C. Returns a reference to the same writable object each time, but populated with different data.
D. Returns a reference to a Writable object. The API leaves unspecified whether this is a reused object or a new object.
E. Returns a reference to the same writable object if the next value is the same as the previous value, or a new writable
object otherwise.

Answer: C
Explanation: Calling Iterator.next() will always return the SAME EXACT instance of IntWritable, with the contents of that instance
replaced with the next value. Reference:manupulating iterator in mapreduce

Question No : 50

In the standard word count MapReduce algorithm, why might using a combiner reduce the
overall Job running time?

A. Because combiners perform local aggregation of word counts, thereby allowing the mappers to process input data
faster.
B. Because combiners perform local aggregation of word counts, thereby reducing the number of mappers that need to
run.
C. Because combiners perform local aggregation of word counts, and then transfer that data to reducers without writing
the intermediate data to disk.
D. Because combiners perform local aggregation of word counts, thereby reducing the number of key-value pairs that
need to be snuff let across the network to the reducers.

Answer: A
Explanation: *Simply speaking a combiner can be considered as amini reducerthat will be applied potentially several times still
during the map phase before to send the new (hopefully reduced) set of key/value pairs to the reducer(s). This is why a combiner
must implement the Reducer interface (or extend the Reducer class as of hadoop 0.20). *Combiners are used to increase the
efficiency of a MapReduce program. They are used to aggregate intermediate map output locally on individual mapper outputs.
Combiners can help you reduce the amount of data that needs to be transferred across to the reducers. You can use your reducer
code as a combiner if the operation performed is commutative and associative. The execution of combiner is not guaranteed,
Hadoop may or may not execute a combiner. Also, if required it may execute it more then 1 times. Therefore your MapReduce
jobs should not depend on the combiners execution. Reference:24 Interview Questions & Answers for Hadoop MapReduce
developers,What are combiners? When should I use a combiner in my MapReduce Job?

Question No : 51

What is the behavior of the default partitioner?

https://www.exam-labs.com/exam/CCD-333 16/20
11/13/2019 CCD-333 Exam Tutorial

A. The default partitioner assigns key value pairs to reducers based on an internal random number generator.
B. The default partitioner implements a round robin strategy, shuffling the key value pairs to each reducer in turn. This
ensures an even partition of the key space.
C. The default partitioner computes the hash of the key. Hash values between specific ranges are associated with
different buckets, and each bucket is assigned to a specific reducer.
D. The default partitioner computes the hash of the key and divides that value modulo the number of reducers. The
result determines the reducer assigned to process the key-value pair.
E. The default partitioner computes the hash of the value and takes the mod of that value with the number of reducers.
The result determines the reducer assigned to process the key value pair.

Answer: D
Explanation: The default partitioner computes a hash value for the key and assigns the partition based on this result. The default
Partitioner implementation is called HashPartitioner. It uses the hashCode() method of the key objects modulo the number of
partitions total to determine which partition to send a given (key, value) pair to. In Hadoop, the default partitioner is
HashPartitioner, which hashes a records key to determine which partition (and thus which reducer) the record belongs in.The
number of partition is then equal to the number of reduce tasks for the job. Reference:Getting Started With (Customized)
Partitioning

Question No : 52

Which of the following statements best describes how a large (100 GB) file is stored in
HDFS?

A. The file is divided into variable size blocks, which are stored on multiple data nodes. Each block is replicated three
times by default.
B. The file is replicated three times by default. Eachcopy of the file is stored on a separate datanodes.
C. The master copy of the file is stored on a single datanode. The replica copies are divided into fixed-size blocks, which
are stored on multiple datanodes.
D. The file is divided into fixed-size blocks, which are stored on multiple datanodes. Each block is replicated three times
by default. Multiple blocks from the same file might reside on the same datanode.
E. The file is divided into fixed-size blocks, which are stored on multiple datanodes. Each block is replicated three times
by default.HDFS guarantees that different blocks from the same file are never on the same datanode.

Answer: E
Explanation: HDFS is designed to reliably store very large files across machines in a large cluster. It stores each file as a sequence
of blocks; all blocks in a file except the last block are the same size. The blocks of a file are replicated for fault tolerance. The
block size and replication factor are configurable per file. An application can specify the number of replicas of a file. The
replication factor can be specified at file creation time and can be changed later. Files in HDFS are write-once and have strictly
one writer at any time. The NameNode makes all decisions regarding replication of blocks. HDFS uses rack-aware replica
placement policy. In default configuration there are total 3 copies of a datablock on HDFS, 2 copies are stored on datanodes on
same rack and 3rd copy on a different rack. Reference:24 Interview Questions & Answers for Hadoop MapReduce developers,How
the HDFS Blocks are replicated?

Question No : 53

What is the difference between a failed task attempt and a killed task attempt?

A. A failed task attempt is a task attempt that threw an unhandled exception. A killed task attempt is one that was
terminated by the JobTracker.
B. A failed task attempt is a task attempt that did not generate any key value pairs. A killed task attempt is a task
attempt that threw an exception, and thus killed by the execution framework.
C. A failed task attempt is a task attempt that completed, but with an unexpected status value. A killed task attempt is a
duplicate copy of a task attempt that was started as part of speculative execution.
D. A failed task attempt is a task attempt that threw a RuntimeException (i.e., the task fails). A killed task attempt is a
task attempt that threw any other type of exception (e.g., IOException); the execution framework catches these
exceptions and reports them as killed.

Answer: C
Explanation: Note: *Hadoop uses "speculative execution." The same task may be started on multiple boxes. The first one to finish
wins, and the other copies are killed. Failed tasks are tasks that error out. *There are a few reasons Hadoop can kill tasks by his
own decisions: a) Task does not report progress during timeout (default is 10 minutes) b) FairScheduler or CapacityScheduler

https://www.exam-labs.com/exam/CCD-333 17/20
11/13/2019 CCD-333 Exam Tutorial
needs the slot for some other pool (FairScheduler) or queue (CapacityScheduler). c) Speculative execution causes results of task
not to be needed since it has completed on other place. Reference:Difference failed tasks vs killed tasks

Question No : 54

You have an employee who is a Date Analyst and is very comfortable with SQL. He would
like to run ad-hoc analysis on data in your HDFS duster. Which of the following is a data
warehousing software built on top of Apache Hadoop that defines a simple SQL-like query
language well-suited for this kind of user?

A. Pig
B. Hue
C. Hive
D. Sqoop
E. Oozie
F. Flume
G. Hadoop Streaming

Answer: C
Explanation: Hive defines a simple SQL-like query language, called QL, that enables users familiar with SQL to query the data. At
the same time, this language also allows programmers who are familiar with the MapReduce framework to be able to plug in their
custom mappers and reducers to perform more sophisticated analysis that may not be supported by the built-in capabilities of the
language. QL can also be extended with custom scalar functions (UDF's), aggregations (UDAF's), and table functions (UDTF's).
Reference:https://cwiki.apache.org/Hive/(Apache Hive, first sentence and second paragraph)

Question No : 55

Which of the following best describes the workings of TextInputFormat?

A. Input file splits may cross line breaks. A line that crosses tile splits is ignored.
B. The input file is split exactly at the line breaks, so each Record Reader will read a series of complete lines.
C. Input file splits may cross line breaks. A line that crosses file splits is read by the RecordReaders of both splits
containing the broken line.
D. Input file splits may cross line breaks. A line that crosses file splits is read by the RecordReader of the split that
contains the end of the broken line.
E. Input file splits may cross line breaks. A line that crosses file splits is read by the RecordReader of the split that
contains the beginning of the broken line.

Answer: D
Explanation: As the Map operation is parallelized the input file set is first split to several pieces called FileSplits. If an individual
file is so large that it will affect seek time it will be split to several Splits. The splitting does not know anything about the input
file's internal logical structure, for example line-oriented text files are split on arbitrary byte boundaries. Then a new map task is
created per FileSplit. When an individual map task starts it will open a new output writer per configured reduce task. It will then
proceed to read its FileSplit using the RecordReader it gets from the specified InputFormat. InputFormat parses the input and
generates key-value pairs. InputFormat must also handle records that may be split on the FileSplit boundary. For example
TextInputFormat will read the last line of the FileSplit past the split boundary and, when reading other than the first FileSplit,
TextInputFormat ignores the content up to the first newline. Reference:How Map and Reduce operations are actually carried out
http://wiki.apache.org/hadoop/HadoopMapReduce(Map, second paragraph)

Question No : 56

Custom programmer-defined counters in MapReduce are:

A. Lightweight devices for bookkeeping within MapReduce programs.


B. Lightweight devices for ensuring the correctness of a MapReduce program. Mappers Increment counters, and reducers
decrement counters. If at the end of the program the counters read zero, then you are sure that the job completed
correctly.
C. Lightweight devices for synchronization within MapReduce programs. You can use counters to coordinate execution
between a mapper and a reducer.

https://www.exam-labs.com/exam/CCD-333 18/20
11/13/2019 CCD-333 Exam Tutorial

Answer: A
Explanation: Countersare a useful channel for gathering statistics about the job; for quality-control, or for application-level
statistics. They are also useful for problem diagnosis. Hadoop maintains somebuilt-in counters for every job, which reports
various metrics for your job. Hadoop MapReduce also allows the user to define a set of user-defined counters that can be
incremented (or decremented by specifying a negative value as the parameter), by the driver, mapper or the reducer.
Reference:Iterative MapReduce and Counters,Introduction to Iterative MapReduce and Counters
http://hadooptutorial.wikispaces.com/Iterative+MapReduce+and+Counters(counters, second paragraph)

Question No : 57

The NameNode uses RAM for the following purpose:

A. To store the contents of files in HDFS.


B. To store filenames, list of blocks and other meta information.
C. To store the edits log that keeps track of changes in HDFS.
D. To manage distributed read and write locks on files in HDFS.

Answer: B
Explanation: The NameNode is the centerpiece of an HDFS file system. It keeps the directory tree of all files in the file system,
and tracks where across the cluster the file data is kept. It does not store the data of these files itself. There is only One
NameNode process run on any hadoop cluster. NameNode runs on its own JVM process. In a typical production cluster its run on a
separate machine. The NameNode is a Single Point of Failure for the HDFS Cluster. When the NameNode goes down, the file
system goes offline. Client applications talk to the NameNode whenever they wish to locate a file, or when they want to
add/copy/move/delete a file. The NameNode responds the successful requests by returning a list of relevant DataNode servers
where the data lives Reference:24 Interview Questions & Answers for Hadoop MapReduce developers,What is a NameNode? How
many instances of NameNode run on a Hadoop Cluster?

Question No : 58

Can you use MapReduce to perform a relational join on two large tables sharing a key?
Assume that the two tables are formatted as comma-separated file in HDFS.

A. Yes.
B. Yes, but only if one of the tables fits into memory.
C. Yes, so long as both tables fit into memory.
D. No, MapReduce cannot perform relational operations.
E. No, but it can be done with either Pig or Hive.

Answer: A
Explanation: Note: * Join Algorithms in MapReduce A) Reduce-side join B) Map-side join C) In-memory join / Striped Striped
variant variant / Memcached variant * Which join to use? / In-memory join > map-side join > reduce-side join / Limitations of
each? In-memory join: memory Map-side join: sort order and partitioning Reduce-side join: general purpose

Question No : 59

What is a SequenceFile?

A. A SequenceFile contains a binary encoding of an arbitrary number of homogeneous writable objects.


B. A SequenceFile contains a binary encoding of an arbitrary number of heterogeneous writable objects.
C. A SequenceFile contains a binary encoding of an arbitrary number of WritableComparable objects, in sorted order.
D. A SequenceFile contains a binary encoding of an arbitrary number key-value pairs. Each key must be the same type.
Each value must be same type.

Answer: D
Explanation: SequenceFile is a flat file consisting of binary key/value pairs. There are 3 different SequenceFile formats:
Uncompressed key/value records. Record compressed key/value records - only 'values' are compressed here. Block compressed
key/value records - both keys and values are collected in 'blocks' separately and compressed. The size of the 'block' is
configurable. Reference:http://wiki.apache.org/hadoop/SequenceFile

Question No : 60

https://www.exam-labs.com/exam/CCD-333 19/20
11/13/2019 CCD-333 Exam Tutorial

Which MapReduce daemon runs on each slave node and participates in job execution?

A. TaskTracker
B. JobTracker
C. NameNode
D. Secondary NameNode

Answer: A
Explanation: Single instance of a Task Tracker is run on each Slave node. Task tracker is run as a separate JVM process.
Reference:24 Interview Questions & Answers for Hadoop MapReduce developers,What is configuration of a typical slave node on
Hadoop cluster? How many JVMs run on a slave node? http://www.fromdev.com/2010/12/interview-questions-hadoop-
mapreduce.html(See answer to question no. 5)

www.exam-labs.com

https://www.exam-labs.com/exam/CCD-333 20/20

You might also like