वितरित DBMS - विफलता और प्रतिबद्ध

एक डेटाबेस प्रबंधन प्रणाली कई विफलताओं के लिए अतिसंवेदनशील है। इस अध्याय में हम विफलता के प्रकारों का अध्ययन करेंगे और प्रोटोकॉल बनाएंगे। एक वितरित डेटाबेस प्रणाली में, विफलताओं को मोटे तौर पर नरम विफलताओं, कठिन विफलताओं और नेटवर्क विफलताओं में वर्गीकृत किया जा सकता है।

नरम विफलता

नरम विफलता विफलता का प्रकार है जो कंप्यूटर की अस्थिर मेमोरी में नुकसान का कारण बनता है और लगातार भंडारण में नहीं। यहां, मुख्य मेमोरी, बफ़र्स, कैश या रजिस्टरों जैसे गैर-स्थिर भंडारण में संग्रहीत जानकारी खो जाती है। उन्हें सिस्टम क्रैश के रूप में भी जाना जाता है। विभिन्न प्रकार की नरम विफलताएँ निम्नानुसार हैं -

  • ऑपरेटिंग सिस्टम की विफलता।
  • मुख्य मेमोरी क्रैश।
  • लेन-देन की विफलता या गर्भपात।
  • सिस्टम उत्पन्न त्रुटि जैसे पूर्णांक अतिप्रवाह या विभाजन-दर-शून्य त्रुटि।
  • सहायक सॉफ्टवेयर की विफलता।
  • बिजली की विफलता।

कठिन असफलता

एक कठिन विफलता विफलता का प्रकार है जो डिस्क जैसे लगातार या गैर-वाष्पशील भंडारण में डेटा की हानि का कारण बनता है। डिस्क विफलता कुछ डिस्क ब्लॉक में डेटा का भ्रष्टाचार या कुल डिस्क की विफलता का कारण हो सकता है। एक कठिन विफलता के कारण हैं -

  • बिजली की विफलता।
  • मीडिया में दोष।
  • पढ़ो-लिखो खराबी।
  • डिस्क पर सूचना का भ्रष्टाचार।
  • डिस्क की हेड क्रैश पढ़ें / लिखें।

यदि रिजर्व में नया, स्वरूपित और रेडी-टू-यूज़ डिस्क है, तो डिस्क विफलताओं से रिकवरी कम हो सकती है। अन्यथा, अवधि में खरीदारी ऑर्डर प्राप्त करने, डिस्क खरीदने और उसे तैयार करने में लगने वाला समय शामिल है।

नेटवर्क विफलता

नेटवर्क विफलताओं वितरित या नेटवर्क डेटाबेस में प्रचलित हैं। इनमें डेटा की वितरित प्रकृति और नेटवर्क पर डेटा को स्थानांतरित करने के कारण डेटाबेस प्रणाली में प्रेरित त्रुटियां शामिल हैं। नेटवर्क विफलता के कारण इस प्रकार हैं -

  • संचार लिंक विफलता।
  • नेटवर्क संकुलन।
  • स्थानांतरण के दौरान सूचना भ्रष्टाचार।
  • साइट विफलताओं।
  • नेटवर्क विभाजन।

प्रतिबद्ध प्रोटोकॉल

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

कमिट प्वाइंट

समय का वह बिंदु जिस पर निर्णय किया जाता है कि क्या लेन-देन करना या निरस्त करना, प्रतिबद्ध बिंदु के रूप में जाना जाता है। निम्नलिखित एक प्रतिबद्ध बिंदु के गुण हैं।

  • यह उस समय की बात है जब डेटाबेस सुसंगत है।

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

  • इस बिंदु पर, लेनदेन के सभी कार्यों को सफलतापूर्वक निष्पादित किया गया है और उनका प्रभाव लेनदेन लॉग में दर्ज किया गया है।

  • यदि आवश्यक हो, तो इस बिंदु पर, लेन-देन सुरक्षित रूप से पूर्ववत किया जा सकता है।

  • इस बिंदु पर, एक लेनदेन इसके द्वारा आयोजित सभी ताले जारी करता है।

लेन-देन पूर्ववत करें

लेन-देन द्वारा डेटाबेस में किए गए सभी परिवर्तनों को पूर्ववत करने की प्रक्रिया को लेनदेन पूर्ववत या लेन-देन रोलबैक कहा जाता है। यह ज्यादातर नरम विफलता के मामले में लागू किया जाता है।

लेन-देन फिर से करें

लेन-देन द्वारा डेटाबेस में किए गए परिवर्तनों को फिर से लागू करने की प्रक्रिया को ट्रांज़ैक्शन रीडो या ट्रांज़ैक्शन रोल फॉरवर्ड कहा जाता है। यह ज्यादातर एक कठिन विफलता से वसूली के लिए लागू किया जाता है।

लेन देन सुची

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

लेन-देन लॉग के उद्देश्य -

  • लेनदेन करने या समर्थन करने के लिए प्रतिबद्ध प्रोटोकॉल का समर्थन करने के लिए।
  • विफलता के बाद डेटाबेस रिकवरी में सहायता करना।

एक लेन-देन लॉग आमतौर पर डिस्क पर रखा जाता है, ताकि यह नरम विफलताओं से प्रभावित न हो। इसके अतिरिक्त, लॉग को समय-समय पर चुंबकीय टेप जैसे एक अभिलेखीय भंडारण तक बैकअप किया जाता है ताकि इसे डिस्क विफलताओं से भी बचाया जा सके।

लेन-देन लॉग में सूची

लेन-देन लॉग स्थिति की स्थिति के आधार पर पाँच प्रकार की सूचियाँ रखता है। यह सूची पुनर्प्राप्ति प्रबंधक को लेनदेन की स्थिति का पता लगाने के लिए सहायता करती है। स्थिति और संबंधित सूचियां इस प्रकार हैं -

  • एक लेनदेन जिसमें एक लेनदेन प्रारंभ रिकॉर्ड होता है और एक लेनदेन प्रतिबद्ध रिकॉर्ड होता है, एक प्रतिबद्ध लेनदेन होता है - प्रतिबद्ध सूची में बनाए रखा जाता है।

  • एक लेनदेन जिसमें एक लेनदेन प्रारंभ रिकॉर्ड होता है और एक लेनदेन विफल रिकॉर्ड होता है, लेकिन एक लेन-देन गर्भपात रिकॉर्ड नहीं होता है, एक असफल लेनदेन है - असफल सूची में बनाए रखा जाता है।

  • एक लेनदेन जिसमें एक लेनदेन प्रारंभ रिकॉर्ड होता है और एक लेन-देन गर्भपात रिकॉर्ड एक निरस्त लेनदेन होता है - गर्भपात सूची में बनाए रखा जाता है।

  • एक लेनदेन जिसमें एक लेनदेन शुरू रिकॉर्ड होता है और एक लेनदेन पहले-प्रतिबद्ध रिकॉर्ड होता है, वह एक पूर्व-प्रतिबद्ध लेनदेन होता है, यानी एक लेनदेन जहां सभी कार्यों को निष्पादित किया गया है, लेकिन प्रतिबद्ध नहीं है - पहले की सूची में बनाए रखा गया है।

  • एक लेन-देन जिसमें एक लेन-देन शुरू रिकॉर्ड होता है, लेकिन पहले-प्रतिबद्ध, प्रतिबद्ध, गर्भपात या असफल होने का कोई रिकॉर्ड, एक सक्रिय लेनदेन नहीं है - सक्रिय सूची में बनाए रखा जाता है।

तत्काल अद्यतन और आस्थगित अद्यतन

लेन-देन लॉग बनाए रखने के लिए तत्काल अद्यतन और आस्थगित अद्यतन दो तरीके हैं।

में immediate updateमोड, जब कोई लेनदेन निष्पादित होता है, तो लेन-देन द्वारा किए गए अपडेट सीधे डिस्क पर लिखे जाते हैं। पुराने मान और अद्यतन मान डेटाबेस में डिस्क पर लिखने से पहले लॉग पर लिखे जाते हैं। प्रतिबद्ध होने पर, डिस्क में किए गए परिवर्तन स्थायी हो जाते हैं। रोलबैक पर, डेटाबेस में लेन-देन द्वारा किए गए परिवर्तन को छोड़ दिया जाता है और पुराने मानों को लॉग में संग्रहीत पुराने मूल्यों से डेटाबेस में पुनर्स्थापित किया जाता है।

में deferred updateमोड, जब कोई लेन-देन निष्पादित होता है, तो लेन-देन द्वारा डेटाबेस में किए गए अपडेट लॉग फ़ाइल में दर्ज किए जाते हैं। प्रतिबद्ध पर, लॉग में परिवर्तन डिस्क पर लिखे गए हैं। रोलबैक पर, लॉग में परिवर्तन छोड़ दिए जाते हैं और डेटाबेस में कोई परिवर्तन लागू नहीं होते हैं।