DBMS - कंसीडर कंट्रोल

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

  • लॉक आधारित प्रोटोकॉल
  • टाइम स्टैम्प आधारित प्रोटोकॉल

लॉक-आधारित प्रोटोकॉल

लॉक-आधारित प्रोटोकॉल से लैस डेटाबेस सिस्टम एक ऐसे तंत्र का उपयोग करता है जिसके द्वारा कोई भी लेनदेन डेटा को पढ़ या लिख ​​नहीं सकता है जब तक कि वह उस पर एक उपयुक्त लॉक प्राप्त नहीं करता है। ताले दो प्रकार के होते हैं -

  • Binary Locks- डेटा आइटम पर एक लॉक दो राज्यों में हो सकता है; यह या तो लॉक या अनलॉक है।

  • Shared/exclusive- इस प्रकार का लॉकिंग तंत्र उनके उपयोग के आधार पर ताले को अलग करता है। यदि राइट ऑपरेशन करने के लिए डेटा आइटम पर एक लॉक प्राप्त किया जाता है, तो यह एक विशेष लॉक है। एक ही डेटा आइटम पर लिखने के लिए एक से अधिक लेनदेन की अनुमति डेटाबेस को असंगत स्थिति में ले जाएगी। पढ़ें ताले साझा किए जाते हैं क्योंकि कोई डेटा मूल्य नहीं बदला जा रहा है।

चार प्रकार के लॉक प्रोटोकॉल उपलब्ध हैं -

सरलीकृत लॉक प्रोटोकॉल

सरलीकृत लॉक-आधारित प्रोटोकॉल लेनदेन को 'राइट' ऑपरेशन से पहले प्रत्येक ऑब्जेक्ट पर लॉक प्राप्त करने की अनुमति देते हैं। लेनदेन 'राइट' ऑपरेशन को पूरा करने के बाद डेटा आइटम को अनलॉक कर सकते हैं।

प्री-क्लेम लॉक प्रोटोकॉल

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

दो-चरण लॉकिंग 2PL

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

दो-चरण लॉकिंग के दो चरण हैं, एक है growing, जहां सभी ताले लेनदेन द्वारा अधिग्रहित किए जा रहे हैं; और दूसरा चरण सिकुड़ रहा है, जहां लेनदेन द्वारा रखे गए ताले जारी किए जा रहे हैं।

अनन्य (राइट) लॉक का दावा करने के लिए, लेन-देन को पहले साझा (रीड) लॉक का अधिग्रहण करना होगा और फिर इसे अनन्य लॉक में अपग्रेड करना होगा।

सख्त दो-चरण लॉकिंग

स्ट्रिक्ट -2PL का पहला चरण 2PL के समान है। पहले चरण में सभी ताले प्राप्त करने के बाद, लेन-देन सामान्य रूप से निष्पादित होता है। लेकिन 2PL के विपरीत, Strict-2PL उपयोग करने के बाद एक लॉक जारी नहीं करता है। सख्त -2PL कमिट पॉइंट तक सभी ताले रखता है और एक समय में सभी ताले जारी करता है।

सख्त -2PL में कैस्केडिंग गर्भपात नहीं है जैसा कि 2PL करता है।

टाइमस्टैम्प-आधारित प्रोटोकॉल

सबसे अधिक इस्तेमाल किया जाने वाला कंसीलर प्रोटोकॉल टाइमस्टैम्प आधारित प्रोटोकॉल है। यह प्रोटोकॉल टाइमस्टैम्प के रूप में या तो सिस्टम टाइम या लॉजिकल काउंटर का उपयोग करता है।

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

हर लेनदेन में एक टाइमस्टैम्प जुड़ा होता है, और ऑर्डरिंग लेन-देन की उम्र से निर्धारित होती है। 0002 घड़ी के समय में बनाया गया एक लेन-देन इसके बाद आने वाले अन्य सभी लेनदेन की तुलना में पुराना होगा। उदाहरण के लिए, 0004 पर सिस्टम में प्रवेश करने वाला कोई भी लेनदेन 'y' दो सेकंड छोटा है और प्राथमिकता पुराने वाले को दी जाएगी।

इसके अलावा, हर डेटा आइटम को नवीनतम रीड एंड राइट-टाइमस्टैम्प दिया जाता है। इससे सिस्टम को पता चलता है कि डेटा आइटम पर अंतिम 'रीड एंड राइट' ऑपरेशन कब किया गया था।

टाइमस्टैम्प ऑर्डरिंग प्रोटोकॉल

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

  • लेन-देन T i का टाइमस्टैम्प TS (T i ) के रूप में दर्शाया गया है ।
  • डेटा-आइटम एक्स का टाइम-स्टैम्प आर-टाइमस्टैम्प (एक्स) द्वारा दर्शाया गया है।
  • W- टाइमस्टैम्प (X) द्वारा डेटा-आइटम X का टाइम-स्टैम्प निरूपित किया जाता है।

टाइमस्टैम्प ऑर्डरिंग प्रोटोकॉल निम्नानुसार काम करता है -

  • If a transaction Ti issues a read(X) operation −

    • यदि टीएस (टीआई) <डब्ल्यू-टाइमस्टैम्प (एक्स)
      • ऑपरेशन अस्वीकार कर दिया गया।
    • यदि TS (Ti)> = W-टाइमस्टैम्प (X)
      • ऑपरेशन को अंजाम दिया।
    • सभी डेटा-आइटम टाइमस्टैम्प अपडेट किए गए।
  • If a transaction Ti issues a write(X) operation −

    • यदि TS (Ti) <R-टाइमस्टैम्प (X)
      • ऑपरेशन अस्वीकार कर दिया गया।
    • यदि टीएस (टीआई) <डब्ल्यू-टाइमस्टैम्प (एक्स)
      • ऑपरेशन खारिज कर दिया और तिवारी को वापस ले लिया।
    • अन्यथा, ऑपरेशन निष्पादित किया गया।

थॉमस 'नियम लिखें

यह नियम बताता है कि यदि टीएस (टीआई) <डब्ल्यू-टाइमस्टैम्प (एक्स) है, तो ऑपरेशन खारिज कर दिया जाता है और टी आई वापस रोल किया जाता है।

समय-क्रम के आदेश देने के नियमों को अनुसूची दृश्य को क्रमबद्ध बनाने के लिए संशोधित किया जा सकता है।

टी आई रोल बैक करने के बजाय , 'राइट' ऑपरेशन को ही नजरअंदाज कर दिया जाता है।