MapReduce - परिचय
MapReduce अनुप्रयोगों को लिखने के लिए एक प्रोग्रामिंग मॉडल है जो बिग डेटा को कई नोड्स पर समानांतर में संसाधित कर सकता है। MapReduce जटिल डेटा के विशाल मात्रा के विश्लेषण के लिए विश्लेषणात्मक क्षमता प्रदान करता है।
बिग डेटा क्या है?
बिग डेटा बड़े डेटासेट का एक संग्रह है जिसे पारंपरिक कंप्यूटिंग तकनीकों का उपयोग करके संसाधित नहीं किया जा सकता है। उदाहरण के लिए, फेसबुक या यूट्यूब के डेटा की मात्रा को दैनिक आधार पर इकट्ठा करने और प्रबंधित करने की आवश्यकता होती है, बिग डेटा की श्रेणी में आ सकता है। हालांकि, बिग डेटा केवल स्केल और वॉल्यूम के बारे में नहीं है, इसमें निम्न पहलुओं में से एक या अधिक शामिल हैं - वेग, विविधता, वॉल्यूम और जटिलता।
MapReduce क्यों?
पारंपरिक एंटरप्राइज़ सिस्टम में आमतौर पर डेटा को संग्रहीत और संसाधित करने के लिए एक केंद्रीकृत सर्वर होता है। निम्नलिखित चित्रण में एक पारंपरिक उद्यम प्रणाली का एक योजनाबद्ध दृष्टिकोण दर्शाया गया है। पारंपरिक मॉडल निश्चित रूप से स्केलेबल डेटा के विशाल मात्रा को संसाधित करने के लिए उपयुक्त नहीं है और इसे मानक डेटाबेस सर्वर द्वारा समायोजित नहीं किया जा सकता है। इसके अलावा, केंद्रीकृत प्रणाली एक साथ कई फाइलों को संसाधित करते समय बहुत अधिक अड़चन पैदा करती है।
Google ने इस अड़चन के मुद्दे को MapReduce नामक एल्गोरिथ्म का उपयोग करके हल किया। MapReduce एक कार्य को छोटे भागों में विभाजित करता है और उन्हें कई कंप्यूटरों को सौंपता है। बाद में, परिणाम एक स्थान पर एकत्र किए जाते हैं और परिणाम डेटासेट बनाने के लिए एकीकृत किया जाता है।
MapReduce कैसे काम करती है?
MapReduce एल्गोरिथ्म में दो महत्वपूर्ण कार्य हैं, अर्थात् मानचित्र और कमी।
मैप कार्य डेटा का एक सेट लेता है और इसे डेटा के दूसरे सेट में परिवर्तित करता है, जहां व्यक्तिगत तत्व ट्यूपल्स (कुंजी-मूल्य जोड़े) में टूट जाते हैं।
Reduce task एक इनपुट के रूप में Map से आउटपुट लेता है और उन डेटा tuples (की-वैल्यू पेयर) को tuples के एक छोटे से सेट में जोड़ता है।
नक्शा कार्य के बाद कम किया गया कार्य हमेशा किया जाता है।
आइए अब हम प्रत्येक चरण पर एक नज़र डालें और उनके महत्व को समझने की कोशिश करें।
Input Phase - यहां हमारे पास एक रिकॉर्ड रीडर है जो प्रत्येक रिकॉर्ड को एक इनपुट फ़ाइल में अनुवाद करता है और कीपर डेटा को की-वैल्यू जोड़े के रूप में मैपर को भेजता है।
Map - मानचित्र एक उपयोगकर्ता-परिभाषित फ़ंक्शन है, जो कि-वैल्यू जोड़े की एक श्रृंखला लेता है और उनमें से प्रत्येक को शून्य या अधिक कुंजी-वैल्यू जोड़े बनाने के लिए प्रोसेस करता है।
Intermediate Keys - वे मैपर द्वारा उत्पन्न की-वैल्यू पेयर को इंटरमीडिएट की के रूप में जाना जाता है।
Combiner- एक कंबाइन स्थानीय रेड्यूसर का एक प्रकार है जो मानचित्र चरण के समान डेटा को पहचानने योग्य सेटों में समूहित करता है। यह मैपर से मध्यवर्ती कुंजियों को इनपुट के रूप में लेता है और एक उपयोगकर्ता-परिभाषित कोड को एक मैपर के छोटे दायरे में मूल्यों को एकत्र करने के लिए लागू करता है। यह मुख्य MapReduce एल्गोरिथ्म का हिस्सा नहीं है; यह वैकल्पिक है।
Shuffle and Sort- Reducer कार्य फेरबदल और क्रमबद्ध कदम के साथ शुरू होता है। यह स्थानीय मशीन पर समूहीकृत कुंजी-मूल्य जोड़े डाउनलोड करता है, जहां Reducer चल रहा है। अलग-अलग कुंजी-मूल्य जोड़े एक बड़ी डेटा सूची में कुंजी द्वारा सॉर्ट किए जाते हैं। डेटा सूची समतुल्य कुंजियों को एक साथ समूहित करती है ताकि उनके मान Reducer कार्य में आसानी से पुनरावृत्त हो सकें।
Reducer- Reducer इनपुट के रूप में समूहीकृत कुंजी-मान युग्मित डेटा लेता है और उनमें से प्रत्येक पर Reducer फ़ंक्शन चलाता है। यहां, डेटा को कई तरीकों से एकत्रित, फ़िल्टर और संयोजित किया जा सकता है और इसके लिए विस्तृत प्रसंस्करण की आवश्यकता होती है। एक बार निष्पादन समाप्त हो जाने पर, यह अंतिम चरण में शून्य या अधिक कुंजी-मूल्य जोड़े देता है।
Output Phase - आउटपुट चरण में, हमारे पास एक आउटपुट फॉर्मेटर है जो Reducer फ़ंक्शन से अंतिम कुंजी-मूल्य जोड़े का अनुवाद करता है और उन्हें एक रिकॉर्ड लेखक का उपयोग करके एक फ़ाइल पर लिखता है।
आइए एक छोटे आरेख की सहायता से दो कार्यों को समझने का प्रयास करें।
MapReduce-उदाहरण
आइए हम MapReduce की शक्ति को समझने के लिए एक वास्तविक दुनिया का उदाहरण लेते हैं। ट्विटर को प्रति दिन लगभग 500 मिलियन ट्वीट मिलते हैं, जो प्रति सेकंड लगभग 3000 ट्वीट्स हैं। निम्नलिखित दृष्टांत से पता चलता है कि ट्वीटर MapReduce की मदद से अपने ट्वीट का प्रबंधन कैसे करता है।
चित्रण में दिखाया गया है, MapReduce एल्गोरिथ्म निम्नलिखित क्रियाएं करता है -
Tokenize - टोकन के नक्शे में ट्वीट्स को टोकन कर उन्हें कुंजी-मूल्य जोड़े के रूप में लिखते हैं।
Filter - टोकन के नक्शे से अवांछित शब्दों को फ़िल्टर करता है और फ़िल्टर किए गए मानचित्रों को कुंजी-मूल्य जोड़े के रूप में लिखता है।
Count - प्रति शब्द एक टोकन काउंटर बनाता है।
Aggregate Counters - छोटे प्रबंधनीय इकाइयों में समान काउंटर मानों का एक समूह तैयार करता है।