डायनॉम्बीडी - मूल अवधारणाएं
DynamoDB का उपयोग करने से पहले, आपको अपने मूल घटकों और पारिस्थितिकी तंत्र से परिचित होना चाहिए। डायनमोडी पारिस्थितिकी तंत्र में, आप तालिकाओं, विशेषताओं और वस्तुओं के साथ काम करते हैं। एक तालिका आइटम के सेट रखती है, और आइटम विशेषताओं के सेट पकड़ते हैं। एक विशेषता डेटा का एक मूलभूत तत्व है जिसके लिए कोई और अपघटन नहीं है, अर्थात, एक क्षेत्र।
प्राथमिक कुंजी
प्राथमिक कुंजी टेबल आइटम के लिए विशिष्ट पहचान के साधन के रूप में काम करती है, और द्वितीयक सूचकांक क्वेरी लचीलापन प्रदान करते हैं। डायनेमोडीबी टेबल डेटा को संशोधित करके रिकॉर्ड घटनाओं को स्ट्रीम करता है।
तालिका निर्माण के लिए न केवल एक नाम निर्धारित करने की आवश्यकता होती है, बल्कि प्राथमिक कुंजी भी होती है; जो टेबल आइटम की पहचान करता है। कोई भी दो आइटम कुंजी साझा नहीं करते हैं। डायनेमोडीबी दो प्रकार की प्राथमिक कुंजी का उपयोग करता है -
Partition Key- इस साधारण प्राथमिक कुंजी में "विभाजन कुंजी" के रूप में संदर्भित एकल विशेषता शामिल है। आंतरिक रूप से, DynamoDB भंडारण को निर्धारित करने के लिए हैश फ़ंक्शन के लिए इनपुट के रूप में महत्वपूर्ण मूल्य का उपयोग करता है।
Partition Key and Sort Key - यह कुंजी, "समग्र प्राथमिक कुंजी" के रूप में जानी जाती है, इसमें दो विशेषताएं होती हैं।
विभाजन कुंजी और
सॉर्ट की।
डायनॉबीडी एक हैश फ़ंक्शन के लिए पहली विशेषता लागू करता है, और एक ही विभाजन कुंजी के साथ आइटम संग्रहीत करता है; सॉर्ट कुंजी द्वारा निर्धारित उनके आदेश के साथ। आइटम विभाजन कुंजियाँ साझा कर सकते हैं, लेकिन कुंजी नहीं छाँट सकते।
प्राथमिक कुंजी विशेषताएँ केवल स्केलर (एकल) मान की अनुमति देती हैं; और स्ट्रिंग, संख्या, या बाइनरी डेटा प्रकार। गैर-प्रमुख विशेषताओं में ये बाधाएं नहीं हैं।
द्वितीयक सूचकांक
ये इंडेक्स आपको वैकल्पिक कुंजी के साथ टेबल डेटा को क्वेरी करने की अनुमति देते हैं। हालांकि डायनमोडीबी उनके उपयोग को मजबूर नहीं करता है, वे क्वेरी को अनुकूलित करते हैं।
डायनेमोडीबी दो प्रकार के द्वितीयक सूचकांक का उपयोग करता है -
Global Secondary Index - इस इंडेक्स में विभाजन और सॉर्ट कीज़ होती हैं, जो टेबल कीज़ से अलग हो सकती हैं।
Local Secondary Index - यह सूचकांक तालिका के समान एक विभाजन कुंजी रखता है, हालांकि, इसकी सॉर्ट कुंजी भिन्न होती है।
एपीआई
डायनमोबी द्वारा दिए गए एपीआई संचालन में नियंत्रण विमान, डेटा विमान (जैसे, निर्माण, पढ़ना, अपडेट करना और हटाना) और धाराएं शामिल हैं। नियंत्रण विमान संचालन में, आप निम्न उपकरणों के साथ तालिकाओं का निर्माण और प्रबंधन करते हैं -
- CreateTable
- DescribeTable
- ListTables
- UpdateTable
- DeleteTable
डेटा प्लेन में, आप निम्नलिखित टूल्स के साथ CRUD ऑपरेशन करते हैं -
सृजन करना | पढ़ें | अपडेट करें | हटाएं |
---|---|---|---|
PutItem BatchWriteItem |
वस्तु ले आओ BatchGetItem सवाल स्कैन |
UpdateItem | चीज़ें हटाएं BatchWriteItem |
स्ट्रीम ऑपरेशन कंट्रोल टेबल स्ट्रीम। आप निम्न स्ट्रीम टूल की समीक्षा कर सकते हैं -
- ListStreams
- DescribeStream
- GetShardIterator
- GetRecords
थ्रूपुट का प्रावधान किया
तालिका निर्माण में, आप प्रोन्नत थ्रूपुट निर्दिष्ट करते हैं, जो संसाधनों को पढ़ने और लिखने के लिए सुरक्षित रखता है। आप थ्रूपुट को मापने और सेट करने के लिए क्षमता इकाइयों का उपयोग करते हैं।
जब अनुप्रयोग सेट थ्रूपुट से अधिक हो जाते हैं, तो अनुरोध विफल हो जाते हैं। DynamoDB GUI कंसोल सेट की निगरानी और बेहतर और गतिशील प्रावधान के लिए थ्रूपुट का उपयोग करने की अनुमति देता है।
संगति पढ़ें
DynamoDB का उपयोग करता है eventually consistent तथा strongly consistentडायनेमिक एप्लिकेशन आवश्यकताओं का समर्थन करने के लिए पढ़ता है। अंततः सुसंगत रीड हमेशा वर्तमान डेटा वितरित नहीं करते हैं।
दृढ़ता से लगातार पढ़ता हमेशा वर्तमान डेटा (उपकरण विफलता या नेटवर्क समस्याओं के अपवाद के साथ) वितरित करता है। आखिरकार लगातार रीड डिफ़ॉल्ट सेटिंग के रूप में कार्य करता है, जिसमें सच की सेटिंग की आवश्यकता होती हैConsistentRead इसे बदलने के लिए पैरामीटर।
विभाजन
DynamoDB डेटा भंडारण के लिए विभाजन का उपयोग करता है। टेबल के लिए इन भंडारण आवंटन में एसएसडी बैकिंग है और स्वचालित रूप से पूरे क्षेत्र में दोहराई जाती है। DynamoDB सभी विभाजन कार्यों का प्रबंधन करता है, जिसमें किसी उपयोगकर्ता की भागीदारी की आवश्यकता नहीं होती है।
तालिका निर्माण में, तालिका सृजन स्थिति में प्रवेश करती है, जो विभाजन आवंटित करती है। जब यह सक्रिय स्थिति में पहुंचता है, तो आप ऑपरेशन कर सकते हैं। जब आपकी क्षमता अधिकतम हो जाती है या जब आप थ्रूपुट को बदल देते हैं तो सिस्टम विभाजन को बदल देता है।