वितरित डीबीएमएस - कंज्यूमिंग को नियंत्रित करता है
कंसीडर कंट्रोलिंग तकनीक यह सुनिश्चित करती है कि शेड्यूल में लेनदेन और सीरीज़ेबिलिटी के एसीआईडी गुणों को बनाए रखते हुए कई लेनदेन एक साथ निष्पादित किए जाते हैं।
इस अध्याय में, हम समवर्ती नियंत्रण के लिए विभिन्न दृष्टिकोणों का अध्ययन करेंगे।
आधारित संगणना नियंत्रण प्रोटोकॉल लॉक करना
लॉकिंग-आधारित संगामिति नियंत्रण प्रोटोकॉल, डेटा आइटम को लॉक करने की अवधारणा का उपयोग करते हैं। एlockएक डेटा आइटम से जुड़ा एक वैरिएबल है जो यह निर्धारित करता है कि उस डेटा आइटम पर रीड / राइट ऑपरेशन किया जा सकता है या नहीं। आम तौर पर, एक लॉक कम्पेटिबिलिटी मैट्रिक्स का उपयोग किया जाता है जो बताता है कि क्या डेटा आइटम को एक ही समय में दो लेनदेन द्वारा लॉक किया जा सकता है।
लॉकिंग-आधारित संगामिति नियंत्रण प्रणाली एक-चरण या दो-चरण लॉकिंग प्रोटोकॉल का उपयोग कर सकती है।
एक-चरण लॉकिंग प्रोटोकॉल
इस पद्धति में, प्रत्येक लेन-देन उपयोग से पहले एक आइटम को लॉक करता है और जैसे ही इसका उपयोग करना समाप्त हो जाता है, लॉक जारी करता है। यह लॉकिंग विधि अधिकतम संगामिति प्रदान करती है, लेकिन हमेशा क्रमबद्धता को लागू नहीं करती है।
दो-चरण लॉकिंग प्रोटोकॉल
इस विधि में, सभी लॉकिंग ऑपरेशन पहले लॉक-रिलीज़ या अनलॉक ऑपरेशन से पहले होते हैं। लेन-देन में दो चरण शामिल हैं। पहले चरण में, एक लेन-देन केवल उन सभी तालों को प्राप्त करता है जिनकी आवश्यकता है और कोई भी ताला जारी नहीं करता है। इसे विस्तार या कहा जाता हैgrowing phase। दूसरे चरण में, लेनदेन ताले जारी करता है और किसी भी नए ताले का अनुरोध नहीं कर सकता है। इसे कहते हैंshrinking phase।
प्रत्येक लेनदेन जो दो-चरण लॉकिंग प्रोटोकॉल का पालन करता है, को क्रमिक होने की गारंटी दी जाती है। हालांकि, यह दृष्टिकोण दो परस्पर विरोधी लेनदेन के बीच कम समानता प्रदान करता है।
टाइमस्टैम्प कॉन्सैरेसी कंट्रोल एल्गोरिदम
टाइमस्टैम्प-आधारित संगामिति नियंत्रण एल्गोरिदम एक लेनदेन के टाइमस्टैम्प का उपयोग क्रमबद्धता सुनिश्चित करने के लिए एक डेटा आइटम के समवर्ती पहुंच को समन्वयित करने के लिए करते हैं। एक टाइमस्टैम्प एक विशिष्ट पहचानकर्ता है जो डीबीएमएस द्वारा एक लेनदेन को दिया जाता है जो लेनदेन के प्रारंभ समय का प्रतिनिधित्व करता है।
ये एल्गोरिदम सुनिश्चित करते हैं कि लेनदेन उनके टाइमस्टैम्प द्वारा तय किए गए क्रम में हो। एक पुराने लेन-देन को एक छोटे लेनदेन से पहले करना चाहिए, क्योंकि पुराने लेनदेन से पहले एक छोटी प्रणाली में प्रवेश किया जाता है।
टाइमस्टैम्प-आधारित संगामिति नियंत्रण तकनीक क्रमिक शेड्यूल उत्पन्न करती है जैसे कि भाग लेने वाले लेनदेन की उम्र के क्रम में समतुल्य सीरियल शेड्यूल की व्यवस्था की जाती है।
टाइमस्टैम्प आधारित समवर्ती नियंत्रण एल्गोरिदम में से कुछ हैं -
- बुनियादी टाइमस्टैम्प आदेश एल्गोरिथ्म।
- कंजर्वेटिव टाइमस्टैम्प ऑर्डरिंग एल्गोरिदम।
- टाइमस्टैम्प ऑर्डर करने के आधार पर मल्टीवोर्स एल्गोरिथ्म।
टाइमस्टैम्प आधारित आदेश क्रमबद्धता को लागू करने के लिए तीन नियमों का पालन करते हैं -
Access Rule- जब दो लेनदेन एक ही डेटा आइटम को एक साथ एक्सेस करने की कोशिश करते हैं, तो परस्पर विरोधी संचालन के लिए, पुराने लेनदेन को प्राथमिकता दी जाती है। यह पुराने लेनदेन के लिए पहले लेनदेन करने के लिए प्रतीक्षा करने का कारण बनता है।
Late Transaction Rule- यदि किसी छोटे लेनदेन ने डेटा आइटम लिखा है, तो पुराने लेनदेन को उस डेटा आइटम को पढ़ने या लिखने की अनुमति नहीं है। यह नियम पुराने लेनदेन को पहले से ही प्रतिबद्ध होने के बाद पुराने लेनदेन को करने से रोकता है।
Younger Transaction Rule - एक युवा लेनदेन एक डेटा आइटम को पढ़ या लिख सकता है जो पहले से ही पुराने लेनदेन द्वारा लिखा गया है।
आशावादी सम्मिलन नियंत्रण एल्गोरिथम
कम संघर्ष दर वाली प्रणालियों में, क्रमबद्धता के लिए प्रत्येक लेनदेन को मान्य करने का कार्य कम प्रदर्शन कर सकता है। इन मामलों में, क्रमबद्धता के लिए परीक्षण को प्रतिबद्ध होने से ठीक पहले स्थगित कर दिया जाता है। चूंकि संघर्ष की दर कम है, इसलिए लेनदेन को निरस्त करने की संभावना जो कि अनुक्रमिक नहीं है, भी कम है। इस दृष्टिकोण को आशावादी संगोष्ठी नियंत्रण तकनीक कहा जाता है।
इस दृष्टिकोण में, एक लेन-देन का जीवन चक्र निम्नलिखित तीन चरणों में विभाजित है -
Execution Phase - एक लेन-देन डेटा आइटम को मेमोरी में लाता है और उन पर ऑपरेशन करता है।
Validation Phase - एक लेनदेन यह सुनिश्चित करने के लिए चेक करता है कि डेटाबेस में इसके परिवर्तन करने से क्रमबद्धता परीक्षा पास हो जाती है।
Commit Phase - एक लेनदेन डिस्क में मेमोरी में संशोधित डेटा आइटम को वापस लिखता है।
यह एल्गोरिथ्म सत्यापन चरण में क्रमबद्धता को लागू करने के लिए तीन नियमों का उपयोग करता है -
Rule 1- दो लेन-देन टी को देखते हुए मैं और टी जे , अगर टी मैं डेटा आइटम जो टी पढ़ रही है जे लिख रहा है, तो टी मैं के निष्पादन चरण कर सकते हैं ओवरलैप नहीं टी के साथ जे के चरण के लिए प्रतिबद्ध। टी जे प्रतिबद्ध कर सकते हैं के बाद ही टी मैं समाप्त निष्पादन है।
Rule 2- दो लेनदेन T i और T j को देखते हुए , यदि T i वह डेटा आइटम लिख रहा है जिसे T j पढ़ रहा है, तो T i का प्रतिबद्ध चरण T j के निष्पादन चरण के साथ ओवरलैप नहीं हो सकता है । टी जे मैं पहले से ही प्रतिबद्ध होने के बाद ही निष्पादित करना शुरू कर सकता है ।
Rule 3- दो लेन-देन टी को देखते हुए मैं और टी जे , अगर टी मैं डेटा आइटम जो टी लिख रहा है j भी लिख रहा है, तो टी मैं के टी के साथ प्रतिबद्ध चरण कर सकते हैं ओवरलैप नहीं जे एस चरण के लिए प्रतिबद्ध '। टी जे मैं पहले से ही प्रतिबद्ध होने के बाद ही शुरू कर सकता है ।
वितरित सिस्टम में कंसीडर कंट्रोल
इस खंड में, हम देखेंगे कि कैसे वितरित तकनीकों को एक वितरित डेटाबेस सिस्टम में लागू किया जाता है।
वितरित दो-चरण लॉकिंग एल्गोरिथम
वितरित दो-चरण लॉकिंग का मूल सिद्धांत बुनियादी दो-चरण लॉकिंग प्रोटोकॉल के समान है। हालांकि, एक वितरित प्रणाली में लॉक मैनेजर के रूप में नामित साइटें हैं। एक ताला प्रबंधक लेनदेन पर नज़र रखने से ताला अधिग्रहण अनुरोधों को नियंत्रित करता है। विभिन्न साइटों में ताला प्रबंधकों के बीच समन्वय को लागू करने के लिए, कम से कम एक साइट को सभी लेनदेन देखने और लॉक संघर्षों का पता लगाने का अधिकार दिया जाता है।
उन साइटों की संख्या के आधार पर, जो लॉक संघर्षों का पता लगा सकते हैं, वितरित दो-चरण लॉकिंग दृष्टिकोण तीन प्रकार के हो सकते हैं -
Centralized two-phase locking- इस दृष्टिकोण में, एक साइट को सेंट्रल लॉक मैनेजर के रूप में नामित किया गया है। पर्यावरण में सभी साइटें केंद्रीय लॉक मैनेजर का स्थान जानती हैं और लेनदेन के दौरान इससे लॉक प्राप्त करती हैं।
Primary copy two-phase locking- इस दृष्टिकोण में, कई साइटों को लॉक कंट्रोल सेंटर के रूप में नामित किया गया है। इनमें से प्रत्येक साइट पर ताले के एक निर्धारित सेट के प्रबंधन की जिम्मेदारी है। सभी साइटें जानती हैं कि कौन सा डेटा टेबल / टुकड़ा आइटम के लॉक के प्रबंधन के लिए लॉक कंट्रोल सेंटर जिम्मेदार है।
Distributed two-phase locking- इस दृष्टिकोण में, कई लॉक मैनेजर हैं, जहां प्रत्येक लॉक मैनेजर अपने स्थानीय साइट पर संग्रहीत डेटा आइटम के लॉक को नियंत्रित करता है। लॉक मैनेजर का स्थान डेटा वितरण और प्रतिकृति पर आधारित है।
वितरित टाइमस्टैम्प कॉन्सैरेसी कंट्रोल
एक केंद्रीकृत प्रणाली में, किसी भी लेनदेन का टाइमस्टैम्प भौतिक घड़ी रीडिंग द्वारा निर्धारित किया जाता है। लेकिन, वितरित प्रणाली में, किसी भी साइट की स्थानीय भौतिक / तार्किक घड़ी रीडिंग को वैश्विक टाइमस्टैम्प के रूप में उपयोग नहीं किया जा सकता है, क्योंकि वे वैश्विक रूप से अद्वितीय नहीं हैं। तो, टाइमस्टैम्प में साइट आईडी और उस साइट की घड़ी पढ़ने का संयोजन शामिल है।
टाइमस्टैम्प ऑर्डरिंग एल्गोरिदम को लागू करने के लिए, प्रत्येक साइट में एक अनुसूचक होता है जो प्रत्येक लेनदेन प्रबंधक के लिए एक अलग कतार रखता है। लेन-देन के दौरान, एक लेनदेन प्रबंधक साइट के अनुसूचक को एक लॉक अनुरोध भेजता है। अनुसूचक टाइमस्टैम्प क्रम को बढ़ाने के लिए अनुरोध को संबंधित कतार में रखता है। अनुरोधों को उनके टाइमस्टैम्प के क्रम में कतारों के सामने से संसाधित किया जाता है, अर्थात सबसे पुराना।
संघर्ष रेखांकन
एक अन्य तरीका संघर्ष ग्राफ बनाने के लिए है। इसके लिए लेनदेन वर्गों को परिभाषित किया गया है। लेन-देन वर्ग में डेटा सेट के दो सेट होते हैं जिन्हें रीड सेट और राइट सेट कहा जाता है। लेन-देन एक विशेष वर्ग का होता है यदि लेन-देन का रीड सेट क्लास के रीड सेट का सबसेट होता है और लेन-देन का सेट सेट क्लास के राइट सेट का सबसेट होता है। रीड चरण में, प्रत्येक लेनदेन अपने रीड सेट में डेटा आइटम के लिए अपने रीड अनुरोधों को जारी करता है। लेखन चरण में, प्रत्येक लेनदेन अपने लिखित अनुरोध जारी करता है।
उन वर्गों के लिए एक संघर्ष ग्राफ बनाया जाता है जिनसे सक्रिय लेनदेन होते हैं। इसमें ऊर्ध्वाधर, क्षैतिज और विकर्ण किनारों का एक सेट होता है। एक ऊर्ध्वाधर किनारा एक कक्षा के भीतर दो नोड्स को जोड़ता है और वर्ग के भीतर संघर्ष को दर्शाता है। एक क्षैतिज किनारा दो वर्गों में दो नोड्स को जोड़ता है और विभिन्न वर्गों के बीच एक लिखने-लिखने के संघर्ष को दर्शाता है। एक विकर्ण किनारे दो वर्गों में दो नोड्स को जोड़ता है और दो वर्गों के बीच लिखने-पढ़ने या पढ़ने-लिखने के संघर्ष को दर्शाता है।
संघर्ष रेखांकन का विश्लेषण यह पता लगाने के लिए किया जाता है कि क्या एक ही वर्ग में या दो अलग-अलग वर्गों में दो लेन-देन समानांतर में चलाए जा सकते हैं।
वितरित ऑप्टिमिस्टिक कंसीलर कंट्रोल एल्गोरिथम
वितरित आशावादी संगामिति नियंत्रण एल्गोरिथ्म आशावादी संगामिति नियंत्रण एल्गोरिथ्म का विस्तार करता है। इस विस्तार के लिए, दो नियम लागू हैं -
Rule 1- इस नियम के अनुसार, लेन-देन करने पर सभी स्थानों पर लेन-देन को स्थानीय रूप से मान्य किया जाना चाहिए। यदि लेन-देन किसी भी साइट पर अमान्य पाया जाता है, तो उसे निरस्त कर दिया जाता है। स्थानीय सत्यापन यह गारंटी देता है कि लेनदेन उन साइटों पर क्रमबद्धता बनाए रखता है जहां इसे निष्पादित किया गया है। लेन-देन के बाद स्थानीय सत्यापन परीक्षण पास होता है, यह विश्व स्तर पर मान्य है।
Rule 2- इस नियम के अनुसार, लेन-देन स्थानीय सत्यापन परीक्षण पास होने के बाद, यह विश्व स्तर पर मान्य होना चाहिए। वैश्विक मान्यता यह सुनिश्चित करती है कि यदि दो परस्पर विरोधी लेनदेन एक से अधिक साइटों पर एक साथ चलते हैं, तो उन्हें सभी साइटों पर एक ही सापेक्ष क्रम में चलना चाहिए। इसके लिए प्रतिबद्ध होने के बाद अन्य परस्पर विरोधी लेनदेन की प्रतीक्षा करने के लिए लेनदेन की आवश्यकता हो सकती है। यह आवश्यकता एल्गोरिथ्म को कम आशावादी बनाती है क्योंकि किसी साइट पर लेन-देन की पुष्टि होते ही लेनदेन करने में सक्षम नहीं हो सकता है।