वितरित DBMS - डिजाइन रणनीतियाँ

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

डेटा प्रतिकृति

डेटा प्रतिकृति दो या दो से अधिक साइटों पर डेटाबेस की अलग-अलग प्रतियां संग्रहीत करने की प्रक्रिया है। यह वितरित डेटाबेस की एक लोकप्रिय गलती सहिष्णुता तकनीक है।

डेटा प्रतिकृति के लाभ

  • Reliability - किसी भी साइट की विफलता के मामले में, डेटाबेस सिस्टम काम करना जारी रखता है क्योंकि एक कॉपी किसी अन्य साइट पर उपलब्ध है।

  • Reduction in Network Load- चूंकि डेटा की स्थानीय प्रतियां उपलब्ध हैं, इसलिए क्वेरी प्रसंस्करण को कम नेटवर्क उपयोग के साथ किया जा सकता है, विशेष रूप से प्राइम घंटों के दौरान। डेटा अपडेट नॉन-प्राइम घंटों में किया जा सकता है।

  • Quicker Response - डेटा की स्थानीय प्रतियों की उपलब्धता त्वरित क्वेरी प्रसंस्करण और इसके परिणामस्वरूप त्वरित प्रतिक्रिया समय सुनिश्चित करती है।

  • Simpler Transactions- लेन-देन के लिए विभिन्न साइटों पर स्थित तालिकाओं के कम संख्या और नेटवर्क में न्यूनतम समन्वय की आवश्यकता होती है। इस प्रकार, वे प्रकृति में सरल हो जाते हैं।

डेटा प्रतिकृति के नुकसान

  • Increased Storage Requirements- डेटा की कई प्रतियों को बनाए रखना भंडारण की बढ़ती लागत के साथ जुड़ा हुआ है। आवश्यक भंडारण स्थान एक केंद्रीयकृत प्रणाली के लिए आवश्यक भंडारण के गुणकों में है।

  • Increased Cost and Complexity of Data Updating- जब भी कोई डेटा आइटम अपडेट किया जाता है, तो अपडेट को विभिन्न साइटों पर डेटा की सभी प्रतियों में परिलक्षित होना चाहिए। इसके लिए जटिल सिंक्रोनाइज़ेशन तकनीक और प्रोटोकॉल की आवश्यकता होती है।

  • Undesirable Application – Database coupling- यदि जटिल अपडेट तंत्र का उपयोग नहीं किया जाता है, तो डेटा असंगतता को हटाने के लिए आवेदन स्तर पर जटिल समन्वय की आवश्यकता होती है। यह अवांछनीय अनुप्रयोग में परिणाम देता है - डेटाबेस युग्मन।

कुछ आमतौर पर इस्तेमाल की जाने वाली प्रतिकृति तकनीकें हैं -

  • स्नैपशॉट प्रतिकृति
  • निकट-वास्तविक समय प्रतिकृति
  • प्रतिकृति खींचो

विखंडन

विखंडन एक तालिका को छोटे तालिकाओं के एक सेट में विभाजित करने का कार्य है। तालिका के सबसेट को कहा जाता हैfragments। विखंडन तीन प्रकार के हो सकते हैं: क्षैतिज, ऊर्ध्वाधर और संकर (क्षैतिज और ऊर्ध्वाधर का संयोजन)। क्षैतिज विखंडन को आगे दो तकनीकों में वर्गीकृत किया जा सकता है: प्राथमिक क्षैतिज विखंडन और व्युत्पन्न क्षैतिज विखंडन।

विखंडन को एक तरह से किया जाना चाहिए ताकि मूल तालिका को टुकड़ों से फिर से संगठित किया जा सके। यह आवश्यक है ताकि जब भी आवश्यक हो, मूल तालिका को टुकड़ों से फिर से संगठित किया जा सके। इस आवश्यकता को "पुनर्संरचना" कहा जाता है।

विखंडन के लाभ

  • चूंकि डेटा उपयोग की साइट के करीब संग्रहीत किया जाता है, डेटाबेस सिस्टम की दक्षता बढ़ जाती है।

  • स्थानीय क्वेरी ऑप्टिमाइज़ेशन तकनीक अधिकांश प्रश्नों के लिए पर्याप्त हैं क्योंकि डेटा स्थानीय रूप से उपलब्ध है।

  • चूंकि अप्रासंगिक डेटा साइटों पर उपलब्ध नहीं है, इसलिए डेटाबेस सिस्टम की सुरक्षा और गोपनीयता को बनाए रखा जा सकता है।

विखंडन के नुकसान

  • जब अलग-अलग टुकड़ों से डेटा की आवश्यकता होती है, तो एक्सेस गति बहुत अधिक हो सकती है।

  • पुनरावर्ती टुकड़ों के मामले में, पुनर्निर्माण के काम के लिए महंगी तकनीकों की आवश्यकता होगी।

  • विभिन्न साइटों में डेटा की बैक-अप प्रतियों की कमी से साइट की विफलता के मामले में डेटाबेस अप्रभावी हो सकता है।

लंबवत विखंडन

ऊर्ध्वाधर विखंडन में, तालिका के फ़ील्ड या कॉलम को टुकड़ों में वर्गीकृत किया जाता है। पुनर्निर्माण को बनाए रखने के लिए, प्रत्येक टुकड़े में तालिका का प्राथमिक मुख्य क्षेत्र (s) होना चाहिए। डेटा की गोपनीयता को लागू करने के लिए ऊर्ध्वाधर विखंडन का उपयोग किया जा सकता है।

उदाहरण के लिए, हमें विचार करना चाहिए कि विश्वविद्यालय का डेटाबेस निम्नलिखित स्कीमा वाले छात्र तालिका में सभी पंजीकृत छात्रों के रिकॉर्ड रखता है।

छात्र

Regd_No नाम कोर्स पता छमाही फीस निशान

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

CREATE TABLE STD_FEES AS 
   SELECT Regd_No, Fees 
   FROM STUDENT;

क्षैतिज विखंडन

क्षैतिज विखंडन एक या अधिक क्षेत्रों के मूल्यों के अनुसार एक टेबल के टुपल्स को समूहित करता है। क्षैतिज विखंडन भी पुनर्निर्माण के नियम की पुष्टि करना चाहिए। प्रत्येक क्षैतिज टुकड़े में मूल आधार तालिका के सभी कॉलम होने चाहिए।

उदाहरण के लिए, छात्र स्कीमा में, यदि कंप्यूटर साइंस कोर्स के सभी छात्रों के विवरण को स्कूल ऑफ कंप्यूटर साइंस में बनाए रखने की आवश्यकता है, तो डिजाइनर क्षैतिज रूप से डेटाबेस को निम्न प्रकार से खंडित करेंगे -

CREATE COMP_STD AS 
   SELECT * FROM STUDENT  
   WHERE COURSE = "Computer Science";

हाइब्रिड फ्रैग्मेंटेशन

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

हाइब्रिड विखंडन दो वैकल्पिक तरीकों से किया जा सकता है -

  • सबसे पहले, क्षैतिज टुकड़ों का एक सेट उत्पन्न करें; फिर क्षैतिज अंशों में से एक या अधिक से ऊर्ध्वाधर टुकड़े उत्पन्न करें।

  • सबसे पहले, ऊर्ध्वाधर टुकड़ों का एक सेट उत्पन्न करें; फिर एक या एक से अधिक लम्बे टुकड़ों से क्षैतिज टुकड़े उत्पन्न करें।