HADOOP INTERVIEW QUESTIONS PART-1
Frequently asked Hadoop Interview Questions:
(click to view answers)
1. What does ‘jps’ command do?
It gives the status of the daemons which run Hadoop cluster. It gives the output mentioning the status of namenode, datanode , secondary namenode, Job tracker and Task tracker.
2. How to restart Namenode?
Step1. Click on stop-all.sh and then click on start-all.sh
Step2. Write sudo hdfs (press enter), su hdfs (press enter), /etc/init.d/ha (press enter) and then /etc/init.d/hadoop0.20namenode start (press enter).
3.Which are the three modes in which Hadoop can be run?
The three modes in which Hadoop can be run are −
standalone (local) mode
Fully distributed mode
4. What does /etc /init.d do?
/etc /init.d specifies where daemons (services) are placed or to see the status of these daemons. It is very LINUX specific, and nothing to do with Hadoop.
5. What if a Namenode has no data?
It cannot be part of the Hadoop cluster.
6. What happens to job tracker when Namenode is down?
When Namenode is down, your cluster is OFF, this is because Namenode is the single point of failure in HDFS.
7. What is Big Data?
Big Data is nothing but an assortment of such a huge and complex data that it becomes very tedious to capture, store, process, retrieve and analyze it with the help of onhand database management tools or traditional data processing techniques.
8. How big data analysis helps businesses increase their revenue? Give example.
Big data analysis is helping businesses differentiate themselves
– for example Walmart the world’s largest retailer in 2014 in terms of revenue is using big data analytics to increase its sales through better predictive analytics, providing customized recommendations and launching new products based on customer preferences and needs. Walmart observed a significant 10% to 15% increase in online sales for $1 billion in incremental revenue.
Effective analysis of Big Data provides a lot of business advantage as organizations will learn which areas to focus on and which areas are less important. Big data analysis provides some early key indicators that can prevent the company from a huge loss or help in grasping a great opportunity with open hands! A precise analysis of Big Data helps in decision making!
There are many more companies like Facebook, Twitter, LinkedIn, Pandora, JPMorgan Chase, Bank of America, etc. using big data analytics to boost their revenue.
9. What do the four V’s of Big Data denote? (OR) What are the four characteristics of Big Data?
The four characteristics of Big Data are
(i). Volume − Scale of data.
Facebook generating 500+ terabytes of data per day.
(ii). Velocity − Analysis of streaming data.
Analyzing 2 million records each day to identify the reason for losses.
(iii). Variety − Different forms of data.
images, audio, video, sensor data, log files, etc.
(iv). Veracity − Uncertainty of data.
biases, noise and abnormality in data.
10. Why do we need Hadoop?
Everyday a large amount of unstructured data is getting dumped into our machines. The major challenge is not to store large data sets in our systems but to retrieve and analyze the big data in the organizations, that too data present in different machines at different locations. In this situation a necessity for Hadoop arises.
Hadoop has the ability to analyze the data present in different machines at different locations very quickly and in a very cost effective way. It uses the concept of MapReduce which enables it to divide the query into small parts and process them in parallel. This is also known as parallel computing.
11. What is Hadoop?
Hadoop is a distributed computing platform. It is an opensource software framework for storing data and running applications on clusters of commodity hardware. It provides enormous processing power and massive storage for any type of data. It is written in Java. It consist of the features like Google File System and MapReduce.
12. Mention what is the difference between an RDBMS and Hadoop?
|1. RDBMS is relational database management system.||1. Hadoop is node based flat structure.|
|2. It used for OLTP processing whereas Hadoop.||2. It is currently used for analytical and for BIG DATA processing.|
|3. In RDBMS, the database cluster uses the same data files stored in shared storage.||3. In Hadoop, the storage data can be stored independently in each processing node.|
|4. You need to preprocess data before storing it.||4. You don’t need to preprocess data before storing it.|
|5. Traditional RDBMS is used for transactional systems to report and archive the data.||5. Hadoop is an approach to store huge amount of data in the distributed file system and process it.|
|6. RDBMS will be useful when you want to seek one record from Big data.||6. Hadoop will be useful when you want Big data in one shot and perform analysis on that later.|
13. What is Fault Tolerance?
In a file stored in a system, and due to some technical problem that file gets destroyed.
Then there is no chance of getting the data back present in that file. To avoid such situations, Hadoop has introduced the feature of fault tolerance in HDFS.
In Hadoop, when we store a file, it automatically gets replicated at two other locations also. So even if one or two of the systems collapse, the file is still available on the third system.
14. Replication causes data redundancy, then why is it pursued in HDFS?
HDFS works with commodity hardware (systems with average configurations) that has high chances of getting crashed any time. Thus, to make the entire system highly faulttolerant, HDFS replicates and stores data in different places. Any data on HDFS gets stored at least 3 different locations. So, even if one of them is corrupted and the other is unavailable for some time for any reason, then data can be accessed from the third one. Hence, there is no chance of losing the data. This replication factor helps us to attain the feature of Hadoop called Fault Tolerant.
15. Since the data is replicated thrice in HDFS, does it mean that any calculation done on one node will also be replicated on the other two?
No, calculations will be done only on the original data. The master node will know which node exactly has that particular data. In case, if one of the nodes is not responding, it is assumed to be failed. Only then, the required calculation will be done on the second replica.
16. What is a Namenode?
Namenode is the master node on which job tracker runs and consists of the metadata. It maintains and manages the blocks which are present on the datanodes. It is a highavailability machine and single point of failure in HDFS.
17. Is Namenode also a commodity hardware?
No. Namenode can never be commodity hardware because the entire HDFS reply on it. It is the single point of failure in HDFS. Namenode has to be a highavailability machine.
18. What is a Datanode?
Datanodes are the slaves which are deployed on each machine and provide the actual storage. These are responsible for serving read and write requests for the clients.
19. Why do we use HDFS for applications having large data sets and not when there are lot of small files?
HDFS is more suitable for large amount of data sets in a single file as compared to small amount of data spread across multiple files. This is because Namenode is a very expensive high performance system, so it is not prudent to occupy the space in the Namenode by unnecessary amount of metadata that is generated for multiple small files.
So, when there is a large amount of data in a single file, name node will occupy less space. Hence for getting optimized performance, HDFS supports large data sets instead of multiple small files.
20. Name some companies that use Hadoop.
Yahoo (One of the biggest user & more than 80% code contributor to Hadoop), Facebook, Netflix, Amazon, Adobe, eBay, Hulu, Spotify, Rubikloud, Twitter.
21. What are the most common input formats defined in Hadoop?
TextInputFormat is a by default input format.
22. What is the difference between TextInputFormat and KeyValueInputFormat class?
TextInputFormat: It reads lines of text files and provides the offset of the line as key to the Mapper and actual line as Value to the mapper.
KeyValueInputFormat: Reads text file and parses lines into key, Val pairs. Everything up to the first tab character is sent as key to the Mapper and the remainder of the line is sent as value to the mapper.
23. What is InputSplit in Hadoop?
When a hadoop job runs, it splits input files into chunks and assign each split to a mapper for processing. It is called InputSplit.
24. How is the splitting of file invoked in Hadoop framework?
It is invoked by the Hadoop framework by running getInputSplit()method of the Input format class (like FileInputFormat) defined by the user.
25. What is a job tracker?
Job tracker is a daemon that runs on a namenode for submitting and tracking MapReduce jobs in Hadoop. It assigns the tasks to the different task tracker. In a Hadoop cluster, there will be only one job tracker but many task trackers. It is the single point of failure for Hadoop and MapReduce Service. If the job tracker goes down all the running jobs are halted. It receives heartbeat from task tracker based on which Job tracker decides whether the assigned task is completed or not.
26. What is a task tracker?
( TaskTracker is a node in the cluster that accepts tasks like MapReduce and Shuffle operations from a JobTracker. ) Task tracker is also a daemon that runs on datanodes. Task Trackers manage the execution of individual tasks on slave node.
When a client submits a job, the job tracker will initialize the job and divide the work and assign them to different task trackers to perform MapReduce tasks. While performing this action, the task tracker will be simultaneously communicating with job tracker by sending heartbeat.
If the job tracker does not receive heartbeat from task tracker within specified time, then it will assume that task tracker has crashed and assign that task to another task tracker in the cluster.
27. What is a heartbeat in HDFS?
A heartbeat is a signal indicating that it is alive. A datanode sends heartbeat to Namenode and task tracker will send its heart beat to job tracker. If the Namenode or job tracker does not receive heart beat then they will decide that there is some problem in datanode or task tracker is unable to perform the assigned task.
28. What is a ‘block’ in HDFS?
A ‘block’ is the minimum amount of data that can be read or written. In HDFS, the default block size is 128 MB as contrast to the block size of 8192 bytes in Unix/Linux. Files in HDFS are broken down into blocksized chunks, which are stored as independent units. HDFS blocks are large as compared to disk blocks, particularly to minimize the cost of seeks.
28.1. If a particular file is 90 mb, will the HDFS block still consume 128 mb as the default size?
No, not at all! 128 mb is just a unit where the data will be stored. In this particular situation, only 90mb will be consumed by an HDFS block and 38 mb will be free to store something else. It is the MasterNode that does data allocation in an efficient manner.
29. What are the benefits of block transfer?
A file can be larger than any single disk in the network. There’s nothing that requires the blocks from a file to be stored on the same disk, so they can take advantage of any of the disks in the cluster. Making the unit of abstraction a block rather than a file simplifies the storage subsystem. Blocks provide fault tolerance and availability.
To insure against corrupted blocks and disk and machine failure, each block is replicated to a small number of physically separate machines (typically three). If a block becomes unavailable, a copy can be read from another location in a way that is transparent to the client.
30. How indexing is done in HDFS?
Hadoop has its own way of indexing. Depending upon the block size, once the data is stored, HDFS will keep on storing the last part of the data which will say where the next part of the data will be.
31. After the Map phase finishes, the Hadoop framework does “Partitioning, Shuffle and sort”. Explain what happens in this phase?
Partitioning: It is the process of determining which reducer instance will receive which intermediate keys and values. Each mapper must determine for all of its output (key, value) pairs which reducer will receive them. It is necessary that for any key, regardless of which mapper instance generated it, the destination partition is the same.
Shuffle: After the first map tasks have completed, the nodes may still be performing several more map tasks each. But they also begin exchanging the intermediate outputs from the map tasks to where they are required by the reducers. This process of moving map outputs to the reducers is known as shuffling.
Sort: Each reduce task is responsible for reducing the values associated with several intermediate keys. The set of intermediate keys on a single node is automatically sorted by Hadoop before they are presented to the Reducer.
32. If no custom partitioner is defined in Hadoop then how is data partitioned before it is sent to the reducer?
The default partitioner computes a hash value for the key and assigns the partition based on this result.
33. Are job tracker and task trackers present in separate machines?
Yes, job tracker and task tracker are present in different machines. The reason is job tracker is a single point of failure for the Hadoop MapReduce service. If it goes down, all running jobs are halted.
34. What is the communication channel between client and namenode/datanode?
The mode of communication is SSH.
35. What is a rack?
Rack is a storage area with all the datanodes put together. These datanodes can be physically located at different places. Rack is a physical collection of datanodes which are stored at a single location. There can be multiple racks in a single location.
36. What is a Secondary Namenode? Is it a substitute to the Namenode?
The secondary Namenode constantly reads the data from the RAM of the Namenode and writes it into the hard disk or the file system. It is not a substitute to the Namenode, so if the Namenode fails, the entire Hadoop system goes down.
37. Explain how do ‘map’ and ‘reduce’ works.
Namenode takes the input and divide it into parts and assign them to data nodes. These datanodes process the tasks assigned to them and make a keyvalue pair and returns the intermediate output to the Reducer. The reducer collects this key value pairs of all the datanodes and combines them and generates the final output.
38. Why ‘Reading‘ is done in parallel and ‘Writing‘ is not in HDFS?
Through mapreduce program the file can be read by splitting its blocks when reading. But while writing as the incoming values are not yet known to the system mapreduce cannot be applied and no parallel writing is possible.
Copy a directory from one node in the cluster to another
Use ‘distcp’ command to copy,
Default replication factor to a file is 3.
Use ‘setrep’ command to change replication factor of a file to 2.
hadoop fs setrep w 2 apache_hadoop/sample.txt
39. What is rack awareness?
Rack awareness is the way in which the namenode decides how to place blocks based on the rack definitions. Hadoop will try to minimize the network traffic between datanodes within the same rack and will only contact remote racks if it has to. The namenode is able to control this due to rack awareness.
40. Which file does the Hadoopcore configuration?
Is there a hdfs command to see available free space in hdfs
hadoop dfs admin report
41. The requirement is to add a new data node to a running Hadoop cluster; how do I start services on just one data node?
You do not need to shutdown and/or restart the entire cluster in this case.
First, add the new node’s DNS name to the conf/slaves file on the master node.
Then log in to the new slave node and execute −
$ cd path/to/hadoop
$ bin/hadoopdaemon.sh start datanode
$ bin/hadoopdaemon.sh start tasktracker
Then issue hadoop dfsadmin refreshNodes and hadoop mradmin refreshNodes so that the NameNode and JobTracker know of the additional node that has been added.
42. How do you gracefully stop a running job?
Hadoop job –kill jobid
43. Does the namenode stay in safe mode till all underreplicated files are fully replicated?
No. During safe mode replication of blocks is prohibited. The namenode awaits when all or majority of datanodes report their blocks.
44. What happens if one Hadoop client renames a file or a directory containing this file while another client is still writing into it?
A file will appear in the name space as soon as it is created. If a writer is writing to a file and another client renames either the file itself or any of its path components, then the original writer will get an IOException either when it finishes writing to the current block or when it closes the file.
45. How to make a large cluster smaller by taking out some of the nodes?
Hadoop offers the decommission feature to retire a set of existing datanodes. The nodes to be retired should be included into the exclude file, and the exclude file name should be specified as a configuration parameter dfs.hosts.exclude.
The decommission process can be terminated at any time by editing the configuration or the exclude files and repeating the refreshNodes command
46. Can we search for files using wildcards?
Yes. For example, to list all the files which begin with the letter a, you could use the ls command with the * wildcard & menu;
hdfs dfs –ls a*
47. What happens when two clients try to write into the same HDFS file?
HDFS supports exclusive writes only.
When the first client contacts the namenode to open the file for writing, the namenode grants a lease to the client to create this file. When the second client tries to open the same file for writing, the namenode will see that the lease for the file is already granted to another client, and will reject the open request for the second client.
48. What does “file could only be replicated to 0 nodes, instead of 1” mean?
The namenode does not have any available DataNodes.
49. What is a Combiner?
The Combiner is a ‘minireduce’ process which operates only on data generated by a mapper. The Combiner will receive as input all data emitted by the Mapper instances on a given node. The output from the Combiner is then sent to the Reducers, instead of the output from the Mappers
Consider case scenario: In M/R system, HDFS block size is 128 MB
Input format is FileInputFormat
– We have 3 files of size 64K, 65Mb and 127Mb, How many input splits will be made by Hadoop framework?
1 split for 64K files
2 splits for 65MB files
third splits for 127MB files
50. Suppose Hadoop spawned 100 tasks for a job and one of the task failed. What will Hadoop do?
It will restart the task again on some other TaskTracker and only if the task fails more than four ( the default setting and can be changed) times will it kill the job.