वितरित DBMS - प्रतिकृति नियंत्रण

यह अध्याय प्रतिकृति नियंत्रण में दिखता है, जिसे सभी साइटों में लगातार डेटा बनाए रखने की आवश्यकता होती है। हम प्रतिकृति नियंत्रण तकनीकों और प्रतिकृति नियंत्रण के लिए आवश्यक एल्गोरिदम का अध्ययन करेंगे।

जैसे कि पहले भी चर्चा की जा चुकी है, replicationअलग-अलग साइटों पर डेटा तालिका की कई प्रतियों को संग्रहीत करने के लिए वितरित डेटाबेस में उपयोग की जाने वाली तकनीक है। कई साइटों में कई प्रतियां होने के साथ समस्या यह है कि विशेष रूप से अद्यतन कार्यों के दौरान डेटा स्थिरता बनाए रखने की ओवरहेड है।

सभी साइटों में पारस्परिक रूप से लगातार डेटा बनाए रखने के लिए, प्रतिकृति नियंत्रण तकनीकों को अपनाने की आवश्यकता है। प्रतिकृति नियंत्रण के लिए दो दृष्टिकोण हैं, अर्थात् -

  • सिंक्रोनस प्रतिकृति नियंत्रण
  • अतुल्यकालिक प्रतिकृति नियंत्रण

सिंक्रोनस प्रतिकृति नियंत्रण

तुल्यकालिक प्रतिकृति दृष्टिकोण में, डेटाबेस को सिंक्रनाइज़ किया जाता है ताकि सभी प्रतिकृति में हमेशा समान मूल्य हो। डेटा आइटम का अनुरोध करने वाले लेन-देन की सभी साइटों में समान मूल्य तक पहुंच होगी। इस एकरूपता को सुनिश्चित करने के लिए, डेटा आइटम को अपडेट करने वाले लेन-देन का विस्तार किया जाता है ताकि वह डेटा आइटम की सभी प्रतियों में अपडेट कर सके। आमतौर पर, दो-चरण प्रतिबद्ध प्रोटोकॉल का उपयोग उद्देश्य के लिए किया जाता है।

उदाहरण के लिए, आइए एक डेटा टेबल PROJECT (PId, PName, PLocation) पर विचार करें। हमें एक लेनदेन T1 चलाने की आवश्यकता है, जो कि 'मुंबई' के लिए, '' बॉम्बे '' के लिए 'प्लॉटोकेशन' को अपडेट करता है। यदि कोई प्रतिकृति नहीं है, तो लेनदेन T1 में परिचालन होगा -

Begin T1: 
   Update PROJECT Set PLocation = 'Mumbai' 
   Where PLocation = 'Bombay'; 
End T1;

यदि साइट A और साइट B में डेटा तालिका में दो प्रतिकृतियां हैं, तो T1 को दो बच्चों T1A और T1B को दो साइटों के अनुरूप बनाना होगा। विस्तारित लेनदेन T1 होगा -

Begin T1: 
   Begin T1A : 
      Update PROJECT Set PLocation = 'Mumbai' 
      Where PLocation = 'Bombay'; 
   End T1A;  
	
   Begin T2A : 
      Update PROJECT Set PLocation = 'Mumbai'
      Where PLocation = 'Bombay'; 
   End T2A; 
	
End T1;

अतुल्यकालिक प्रतिकृति नियंत्रण

अतुल्यकालिक प्रतिकृति दृष्टिकोण में, प्रतिकृतियां हमेशा समान मूल्य नहीं रखती हैं। एक या अधिक प्रतिकृतियां एक पुराने मूल्य को संग्रहीत कर सकती हैं, और एक लेनदेन विभिन्न मूल्यों को देख सकता है। सभी प्रतिकृतियों को वर्तमान मूल्य पर लाने की प्रक्रिया को कहा जाता हैsynchronization

सिंक्रनाइज़ेशन की एक लोकप्रिय विधि स्टोर और फॉरवर्ड विधि है। इस पद्धति में, एक साइट को प्राथमिक साइट के रूप में नामित किया गया है और अन्य साइटें द्वितीयक साइट हैं। प्राथमिक साइट में हमेशा अद्यतन मान होते हैं। सभी लेनदेन पहले प्राथमिक साइट में प्रवेश करते हैं। ये लेनदेन तब द्वितीयक साइटों में आवेदन के लिए कतारबद्ध हैं। द्वितीयक साइटें केवल रोलआउट पद्धति का उपयोग करके अपडेट की जाती हैं, जब कोई लेनदेन उस पर निष्पादित करने के लिए निर्धारित होता है।

प्रतिकृति नियंत्रण एल्गोरिदम

प्रतिकृति नियंत्रण एल्गोरिदम में से कुछ हैं -

  • मास्टर-दास प्रतिकृति नियंत्रण एल्गोरिथ्म।
  • वितरित एल्गोरिथ्म।
  • अधिकांश आम सहमति एल्गोरिथ्म।
  • टोकन एल्गोरिथ्म घूम रहा है।

मास्टर-स्लेव प्रतिकृति नियंत्रण एल्गोरिथम

एक मास्टर साइट और 'एन' दास साइटें हैं। एक मास्टर एल्गोरिथ्म संघर्ष का पता लगाने के लिए मास्टर साइट पर चलता है। प्रत्येक दास साइट पर दास एल्गोरिथ्म की एक प्रति चलती है। समग्र एल्गोरिथ्म निम्नलिखित दो चरणों में निष्पादित होता है -

  • Transaction acceptance/rejection phase- जब एक लेन-देन एक दास साइट के लेनदेन की निगरानी में प्रवेश करता है, तो दास साइट मास्टर साइट पर एक अनुरोध भेजती है। मास्टर साइट संघर्षों के लिए जाँच करता है। यदि कोई विवाद नहीं है, तो स्वामी दास साइट पर एक "ACK +" संदेश भेजता है जो तब लेनदेन एप्लिकेशन चरण शुरू करता है। अन्यथा, स्वामी दास को "ACK-" संदेश भेजता है जो तब लेनदेन को अस्वीकार कर देता है।

  • Transaction application phase- इस चरण में प्रवेश करने पर, दास साइट जहां लेनदेन में प्रवेश किया गया है, लेनदेन को निष्पादित करने के लिए सभी दासों से अनुरोध करता है। अनुरोध प्राप्त करने पर, सहकर्मी दास लेनदेन को निष्पादित करते हैं और पूरा होने पर अनुरोधकर्ता दास को "एसीके" भेजते हैं। अनुरोध करने के बाद दास को अपने सभी साथियों से "एसीके" संदेश मिले हैं, यह मास्टर साइट पर एक "पूर्ण" संदेश भेजता है। मास्टर समझता है कि लेनदेन पूरा हो गया है और इसे लंबित कतार से हटा देता है।

वितरित एल्गोरिथ्म

इसमें 'एन' सहकर्मी साइटें शामिल हैं, जिनमें से सभी को निष्पादित करने से पहले "ओके" एक लेनदेन होना चाहिए। इस एल्गोरिथ्म के दो चरण निम्नलिखित हैं -

  • Distributed transaction acceptance phase- जब कोई लेन-देन किसी साइट के लेन-देन प्रबंधक में प्रवेश करता है, तो यह अन्य सभी साइटों को लेनदेन का अनुरोध भेजता है। अनुरोध प्राप्त करने पर, एक सहकर्मी साइट प्राथमिकता आधारित मतदान नियमों का उपयोग करके संघर्षों का समाधान करती है। यदि सभी सहकर्मी साइट लेन-देन के साथ "ठीक" हैं, तो अनुरोध करने वाली साइट एप्लिकेशन चरण शुरू करती है। यदि कोई सहकर्मी साइट लेनदेन को "ठीक" नहीं करता है, तो अनुरोध करने वाली साइट लेनदेन को अस्वीकार कर देती है।

  • Distributed transaction application phase- इस चरण में प्रवेश करने पर, जिस स्थान पर लेन-देन दर्ज किया गया है, लेनदेन को निष्पादित करने के लिए सभी दासों से अनुरोध प्रसारित करता है। अनुरोध प्राप्त करने पर, सहकर्मी दास लेनदेन को अंजाम देते हैं और पूरा होने पर अनुरोध करने वाले दास को एक "ACK" संदेश भेजते हैं। अनुरोध करने के बाद दास को अपने सभी साथियों से "एसीके" संदेश मिले हैं, इससे लेनदेन प्रबंधक को पता चलता है कि लेनदेन पूरा हो गया है।

अधिकांश आम सहमति एल्गोरिथ्म

यह वितरित वोटिंग एल्गोरिथ्म से एक भिन्नता है, जहां एक लेन-देन को निष्पादित करने की अनुमति दी जाती है, जब अधिकांश साथी लेनदेन को "ओके" करते हैं। इसे तीन चरणों में बांटा गया है -

  • Voting phase- जब कोई लेन-देन किसी साइट के लेन-देन प्रबंधक में प्रवेश करता है, तो यह अन्य सभी साइटों को लेनदेन का अनुरोध भेजता है। अनुरोध प्राप्त करने पर, एक सहकर्मी मतदान नियमों का उपयोग करते हुए टकरावों के लिए परीक्षण करता है और विवादित लेनदेन को, यदि कोई हो, लंबित कतार में रखता है। फिर, यह या तो "ओके" या "ओके नहीं" संदेश भेजता है।

  • Transaction acceptance/rejection phase- यदि अनुरोध वाली साइट को लेन-देन पर बहुमत "ओके" प्राप्त होता है, तो यह सभी साइटों के लिए लेनदेन और "एसीसीपीटी" प्रसारित करता है। अन्यथा, यह सभी साइटों को "REJECT" प्रसारित करता है और लेनदेन को अस्वीकार करता है।

  • Transaction application phase- जब कोई सहकर्मी साइट "REJECT" संदेश प्राप्त करता है, तो वह अपनी लंबित सूची से इस लेनदेन को हटा देता है और सभी स्थगित लेनदेन पर पुनर्विचार करता है। जब कोई सहकर्मी साइट "ACCEPT" संदेश प्राप्त करता है, तो वह लेन-देन को लागू करता है और लंबित कतार में सभी आस्थगित लेनदेन को अस्वीकार कर देता है जो इस लेनदेन के विरोध में हैं। यह पूरा होने पर अनुरोध करने वाले दास को एक "एसीके" भेजता है।

टोकन एल्गोरिथ्म घूम रहा है

इस दृष्टिकोण में सिस्टम में लेन-देन को एक परिसंचारी टोकन का उपयोग करके क्रमबद्ध किया जाता है और डेटाबेस की प्रत्येक प्रतिकृति के अनुसार निष्पादित किया जाता है। इस प्रकार, सभी लेनदेन स्वीकार किए जाते हैं, अर्थात कोई भी अस्वीकार नहीं किया जाता है। इसके दो चरण हैं -

  • Transaction serialization phase- इस चरण में, सभी लेनदेन क्रमबद्ध क्रम में चलने वाले हैं। प्रत्येक साइट में प्रत्येक लेनदेन को अनुक्रमिक श्रृंखला से एक अद्वितीय टिकट सौंपा गया है, जो लेनदेन के आदेश को दर्शाता है। एक बार लेन-देन का टिकट निर्धारित होने के बाद, इसे सभी साइटों पर प्रसारित किया जाता है।

  • Transaction application phase- जब कोई साइट अपने टिकट के साथ लेनदेन प्राप्त करती है, तो वह अपने टिकट के अनुसार लेनदेन के लिए लेनदेन करती है। लेन-देन का निष्पादन समाप्त होने के बाद, यह साइट एक उपयुक्त संदेश प्रसारित करती है। एक लेनदेन तब समाप्त होता है जब उसने सभी साइटों में निष्पादन पूरा कर लिया है।