डायनॉम्बीडी - त्वरित गाइड
डायनॉबीडी उपयोगकर्ताओं को किसी भी राशि के डेटा को संग्रहीत करने और पुनर्प्राप्त करने में सक्षम डेटाबेस बनाने और किसी भी मात्रा में यातायात की अनुमति देता है। यह स्वचालित रूप से प्रत्येक ग्राहक के अनुरोधों को गतिशील रूप से प्रबंधित करने के लिए सर्वर पर डेटा और ट्रैफ़िक वितरित करता है, और तेज़ प्रदर्शन भी बनाए रखता है।
डायनेमोडी बनाम आरडीबीएमएस
डायनॉबीडी एक नोएसक्यूएल मॉडल का उपयोग करता है, जिसका अर्थ है कि यह एक गैर-संबंधपरक प्रणाली का उपयोग करता है। निम्न तालिका डायनेमोडीबी और आरडीबीएमएस के बीच के अंतर पर प्रकाश डालती है -
आम कार्य | आरडीबीएमएस | DynamoDB |
---|---|---|
Connect to the Source | यह लगातार कनेक्शन और SQL कमांड का उपयोग करता है। | यह HTTP अनुरोधों और एपीआई संचालन का उपयोग करता है |
Create a Table | इसकी मूलभूत संरचनाएं टेबल हैं, और इन्हें परिभाषित किया जाना चाहिए। | यह केवल प्राथमिक कुंजी का उपयोग करता है, और निर्माण पर कोई स्कीमा नहीं है। यह विभिन्न डेटा स्रोतों का उपयोग करता है। |
Get Table Info | सभी तालिका जानकारी सुलभ रहती है | केवल प्राथमिक कुंजी प्रकट की जाती हैं। |
Load Table Data | यह स्तंभों से बनी पंक्तियों का उपयोग करता है। | तालिकाओं में, यह विशेषताओं से बने आइटम का उपयोग करता है |
Read Table Data | यह सेलेक्ट स्टेटमेंट और फ़िल्टरिंग स्टेटमेंट का उपयोग करता है। | इसमें GetItem, Query और Scan का उपयोग किया गया है। |
Manage Indexes | यह एसक्यूएल स्टेटमेंट के जरिए बनाए गए स्टैंडर्ड इंडेक्स का इस्तेमाल करता है। इसमें परिवर्तन स्वचालित रूप से तालिका परिवर्तनों पर होते हैं। | यह समान फ़ंक्शन को प्राप्त करने के लिए एक द्वितीयक सूचकांक का उपयोग करता है। इसके लिए विनिर्देशों (विभाजन कुंजी और सॉर्ट कुंजी) की आवश्यकता होती है। |
Modify Table Data | यह एक अद्यतन कथन का उपयोग करता है। | यह एक UpdateItem ऑपरेशन का उपयोग करता है। |
Delete Table Data | यह एक DELETE कथन का उपयोग करता है। | यह एक DeleteItem ऑपरेशन का उपयोग करता है। |
Delete a Table | यह DROP TABLE स्टेटमेंट का उपयोग करता है। | यह एक DeleteTable ऑपरेशन का उपयोग करता है। |
लाभ
DynamoDB के दो मुख्य लाभ स्केलेबिलिटी और लचीलापन हैं। यह एक विशेष डेटा स्रोत और संरचना के उपयोग को मजबूर नहीं करता है, जिससे उपयोगकर्ता लगभग किसी भी चीज़ के साथ काम कर सकते हैं, लेकिन एक समान तरीके से।
इसका डिज़ाइन लाइटर कार्यों और संचालन से लेकर उद्यम की कार्यक्षमता तक विस्तृत उपयोग का समर्थन करता है। यह कई भाषाओं के सरल उपयोग की भी अनुमति देता है: रूबी, जावा, पायथन, सी #, एर्लांग, पीएचपी और पर्ल।
सीमाओं
डायनेमोबीडी कुछ सीमाओं से ग्रस्त है, हालांकि, ये सीमाएं बहुत बड़ी समस्याएं या ठोस विकास में बाधा नहीं बनती हैं।
आप निम्नलिखित बिंदुओं से उनकी समीक्षा कर सकते हैं -
Capacity Unit Sizes- एक पठन क्षमता इकाई 4KB से बड़ी कोई भी आइटम के लिए प्रति सेकंड एक एकल सुसंगत रीड है। एक लिखने की क्षमता इकाई 1KB से बड़ी वस्तुओं के लिए प्रति सेकंड एक एकल लेखन है।
Provisioned Throughput Min/Max- सभी तालिकाओं और वैश्विक माध्यमिक सूचकांकों में न्यूनतम एक रीड और एक राइट कैपेसिटी यूनिट होती है। मैक्सिमम क्षेत्र पर निर्भर करते हैं। यूएस में, 40K रीड एंड राइट कैप प्रति टेबल (80K प्रति अकाउंट) रहता है, और अन्य क्षेत्रों में 20K अकाउंट कैप के साथ 10K प्रति टेबल कैप होता है।
Provisioned Throughput Increase and Decrease - आप इसे आवश्यकतानुसार जितनी बार बढ़ा सकते हैं, लेकिन घटते-घटते प्रतिदिन चार बार से अधिक नहीं रह जाते हैं।
Table Size and Quantity Per Account - टेबल साइज की कोई सीमा नहीं है, लेकिन जब तक आप एक उच्च कैप का अनुरोध नहीं करते हैं, तब तक खातों की 256 टेबल सीमा होती है।
Secondary Indexes Per Table - पांच स्थानीय और पांच वैश्विक अनुमति है।
Projected Secondary Index Attributes Per Table - DynamoDB 20 विशेषताओं की अनुमति देता है।
Partition Key Length and Values - उनकी न्यूनतम लंबाई 1 बाइट पर बैठती है, और अधिकतम 2048 बाइट पर, हालांकि, डायनेमोबी मूल्यों पर कोई सीमा नहीं रखता है।
Sort Key Length and Values - इसकी न्यूनतम लंबाई 1 बाइट पर होती है, और 1024 बाइट पर अधिकतम, मूल्यों के लिए कोई सीमा नहीं होती है जब तक कि इसकी तालिका स्थानीय माध्यमिक सूचकांक का उपयोग नहीं करती है।
Table and Secondary Index Names - नाम की लंबाई न्यूनतम 3 वर्णों और अधिकतम 255 के अनुरूप होनी चाहिए। वे निम्नलिखित वर्णों का उपयोग करते हैं: AZ, az, 0-9, "_", "-", और "।"
Attribute Names - एक चरित्र न्यूनतम रहता है, और 64KB अधिकतम होता है, जिसमें कुंजियों और कुछ विशेषताओं के अपवाद होते हैं।
Reserved Words - डायनेमोडीबी आरक्षित शब्दों के नाम के उपयोग को नहीं रोकता है।
Expression Length- एक्सप्रेशन स्ट्रिंग्स में 4KB लिमिट होती है। विशेषता अभिव्यक्तियों में 255-बाइट की सीमा होती है। किसी अभिव्यक्ति के प्रतिस्थापन चर में 2MB की सीमा होती है।
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 का उपयोग करता है eventually consistent तथा strongly consistentडायनेमिक एप्लिकेशन आवश्यकताओं का समर्थन करने के लिए पढ़ता है। अंततः सुसंगत रीड हमेशा वर्तमान डेटा वितरित नहीं करते हैं।
दृढ़ता से लगातार पढ़ता हमेशा वर्तमान डेटा (उपकरण विफलता या नेटवर्क समस्याओं के अपवाद के साथ) वितरित करता है। आखिरकार लगातार रीड डिफ़ॉल्ट सेटिंग के रूप में कार्य करता है, जिसमें सच की सेटिंग की आवश्यकता होती हैConsistentRead इसे बदलने के लिए पैरामीटर।
विभाजन
DynamoDB डेटा भंडारण के लिए विभाजन का उपयोग करता है। तालिकाओं के लिए इन संग्रहण आवंटन में SSD बैकिंग है और स्वचालित रूप से पूरे क्षेत्र में दोहराई जाती है। DynamoDB सभी विभाजन कार्यों का प्रबंधन करता है, जिसमें उपयोगकर्ता की भागीदारी की आवश्यकता नहीं होती है।
तालिका निर्माण में, तालिका क्रिएट अवस्था में प्रवेश करती है, जो विभाजन आवंटित करती है। जब यह सक्रिय स्थिति में पहुंचता है, तो आप ऑपरेशन कर सकते हैं। जब आपकी क्षमता अधिकतम हो जाती है या जब आप थ्रूपुट बदलते हैं तो सिस्टम विभाजन को बदल देता है।
डायनमोबी पर्यावरण केवल डायनामोडीबी जीयूआई कंसोल का उपयोग करने के लिए आपके अमेज़ॅन वेब सेवा खाते का उपयोग करता है, हालांकि, आप स्थानीय इंस्टॉल भी कर सकते हैं।
निम्नलिखित वेबसाइट पर नेविगेट करें - https://aws.amazon.com/dynamodb/
यदि आपके पास Amazon Web Services खाता नहीं है, तो “Amazon DynamoDB” बटन के साथ आरंभ करें, या “AWS खाता बनाएँ” बटन पर क्लिक करें। सरल, निर्देशित प्रक्रिया आपको सभी संबंधित शुल्क और आवश्यकताओं से अवगत कराएगी।
प्रक्रिया के सभी आवश्यक चरणों को करने के बाद, आपके पास पहुंच होगी। बस AWS कंसोल में साइन इन करें, और उसके बाद DynamoDB कंसोल पर जाएँ।
संबंधित शुल्क से बचने के लिए अप्रयुक्त या अनावश्यक सामग्री को हटाना सुनिश्चित करें।
स्थानीय स्थापित करें
AWS (Amazon Web Service) स्थानीय प्रतिष्ठानों के लिए DynamoDB का एक संस्करण प्रदान करता है। यह वेब सेवा या कनेक्शन के बिना एप्लिकेशन बनाने का समर्थन करता है। यह एक स्थानीय डेटाबेस को अनुमति देकर प्रोविज़न थ्रूपुट, डेटा स्टोरेज और ट्रांसफर फीस को भी कम करता है। यह मार्गदर्शिका एक स्थानीय इंस्टॉल मानती है।
तैनाती के लिए तैयार होने पर, आप इसे AWS उपयोग में बदलने के लिए अपने आवेदन में कुछ छोटे समायोजन कर सकते हैं।
स्थापित फ़ाइल एक है .jar executable। यह जावा समर्थन के साथ लिनक्स, यूनिक्स, विंडोज और किसी भी अन्य ओएस में चलता है। निम्न लिंक में से किसी एक का उपयोग करके फ़ाइल डाउनलोड करें -
Tarball - http://dynamodb-local.s3-website-us-west2.amazonaws.com/dynamodb_local_latest.tar.gz
Zip archive - http://dynamodb-local.s3-website-us-west2.amazonaws.com/dynamodb_local_latest.zip
Note- अन्य रिपॉजिटरी फ़ाइल की पेशकश करते हैं, लेकिन जरूरी नहीं कि नवीनतम संस्करण। अप-टू-डेट इंस्टॉल फ़ाइलों के लिए ऊपर दिए गए लिंक का उपयोग करें। इसके अलावा, सुनिश्चित करें कि आपके पास जावा रनटाइम इंजन (JRE) संस्करण 6.x या एक नया संस्करण है। DynamoDB पुराने संस्करणों के साथ नहीं चल सकता।
उपयुक्त संग्रह डाउनलोड करने के बाद, इसकी निर्देशिका (DynamoDBLocal.jar) को निकालें और इसे इच्छित स्थान पर रखें।
फिर आप डाइनामो डी बी शुरू कर सकते हैं एक कमांड प्रॉम्प्ट खोलकर, डाइनामो डीबीएलोकल.जर युक्त निर्देशिका में नेविगेट करके और निम्न कमांड दर्ज करके -
java -Djava.library.path=./DynamoDBLocal_lib -jar DynamoDBLocal.jar -sharedDb
आप इसे शुरू करने के लिए उपयोग किए जाने वाले कमांड प्रॉम्प्ट को बंद करके डायनमोबीडी को भी रोक सकते हैं।
काम का माहौल
आप DynamoDB के साथ काम करने के लिए जावास्क्रिप्ट खोल, GUI कंसोल और कई भाषाओं का उपयोग कर सकते हैं। उपलब्ध भाषाओं में रूबी, जावा, पायथन, सी #, एर्लांग, पीएचपी और पर्ल शामिल हैं।
इस ट्यूटोरियल में, हम वैचारिक और कोड स्पष्टता के लिए जावा और जीयूआई कंसोल उदाहरणों का उपयोग करते हैं। जावा का उपयोग करने के लिए जावा आईडीई, जावा के लिए एडब्ल्यूएस एसडीके, और जावा एसडीके के लिए एडब्ल्यूएस सुरक्षा क्रेडेंशियल स्थापित करें।
स्थानीय से वेब सेवा कोड में रूपांतरण
तैनाती के लिए तैयार होने पर, आपको अपना कोड बदलना होगा। समायोजन कोड भाषा और अन्य कारकों पर निर्भर करता है। मुख्य परिवर्तन केवल बदलने के होते हैंendpointएक स्थानीय बिंदु से AWS क्षेत्र तक। अन्य परिवर्तनों के लिए आपके आवेदन के गहन विश्लेषण की आवश्यकता होती है।
एक स्थानीय इंस्टॉल वेब सेवा से कई मायनों में अलग है, लेकिन निम्नलिखित प्रमुख अंतरों तक सीमित नहीं है -
स्थानीय इंस्टॉल तुरंत टेबल बनाता है, लेकिन सेवा में अधिक समय लगता है।
स्थानीय इंस्टॉल थ्रूपुट की अनदेखी करता है।
विलोपन तुरंत एक स्थानीय संस्थापन में होता है।
नेटवर्क ओवरहेड की अनुपस्थिति के कारण स्थानीय इंस्टाल में जल्दी से पढ़ता / लिखता है।
डायनेमोबीडी ऑपरेशन करने के लिए तीन विकल्प प्रदान करता है: एक वेब-आधारित जीयूआई कंसोल, एक जावास्क्रिप्ट शेल, और आपकी पसंद की एक प्रोग्रामिंग भाषा।
इस ट्यूटोरियल में, हम स्पष्टता और वैचारिक समझ के लिए GUI कंसोल और जावा भाषा का उपयोग करने पर ध्यान केंद्रित करेंगे।
जीयूआई कंसोल
Amazon DynamoDB के लिए GUI कंसोल या AWS प्रबंधन कंसोल निम्न पते पर पाया जा सकता है - https://console.aws.amazon.com/dynamodb/home
यह आपको निम्नलिखित कार्य करने की अनुमति देता है -
- CRUD
- तालिका आइटम देखें
- तालिका क्वेरीज़ निष्पादित करें
- तालिका क्षमता की निगरानी के लिए अलार्म सेट करें
- वास्तविक समय में तालिका मेट्रिक्स देखें
- तालिका अलार्म देखें
यदि आपके डायनेमोीडी खाते में कोई टेबल नहीं है, तो एक्सेस पर, यह एक टेबल बनाने के माध्यम से आपका मार्गदर्शन करता है। इसकी मुख्य स्क्रीन आम संचालन करने के लिए तीन शॉर्टकट प्रदान करती है -
- टेबल्स बनाएं
- जोड़ें और क्वेरी तालिकाएँ
- मॉनिटर और टेबल्स का प्रबंधन
जावास्क्रिप्ट खोल
DynamoDB में एक इंटरैक्टिव जावास्क्रिप्ट शेल शामिल है। शेल एक वेब ब्राउज़र के अंदर चलता है, और अनुशंसित ब्राउज़रों में फ़ायरफ़ॉक्स और क्रोम शामिल हैं।
Note - अन्य ब्राउज़रों के उपयोग से त्रुटियां हो सकती हैं।
एक वेब ब्राउज़र खोलकर और निम्नलिखित पते पर प्रवेश करके शेल को एक्सेस करें -http://localhost:8000/shell
बाएँ फलक में JavaScript दर्ज करके और "बाएँ" फलक के ऊपरी दाएँ कोने में "Play" आइकन बटन पर क्लिक करके शेल का उपयोग करें, जो कोड चलाता है। कोड परिणाम दाएँ फलक में प्रदर्शित होते हैं।
डायनमोडी और जावा
अपने जावा विकास वातावरण का उपयोग करके डायनमोबीडी के साथ जावा का उपयोग करें। संचालन सामान्य जावा सिंटैक्स और संरचना की पुष्टि करता है।
डायनमोबी द्वारा समर्थित डेटा प्रकारों में विशेषताओं, कार्यों और पसंद की आपकी कोडिंग भाषा के लिए विशिष्ट शामिल हैं।
डेटा प्रकारों को शामिल करें
डायनेमोडी टेबल विशेषताओं के लिए डेटा प्रकारों के एक बड़े सेट का समर्थन करता है। प्रत्येक डेटा प्रकार तीन निम्न श्रेणियों में से एक में आता है -
Scalar - ये प्रकार एकल मान का प्रतिनिधित्व करते हैं, और संख्या, स्ट्रिंग, बाइनरी, बूलियन और अशक्त शामिल हैं।
Document - ये प्रकार नेस्टेड विशेषताओं वाले एक जटिल संरचना का प्रतिनिधित्व करते हैं, और सूचियों और मानचित्रों को शामिल करते हैं।
Set - ये प्रकार कई स्केल का प्रतिनिधित्व करते हैं, और इसमें स्ट्रिंग सेट, संख्या सेट और बाइनरी सेट शामिल हैं।
डायनामो डीबी को एक योजना के रूप में याद रखें, NoSQL डेटाबेस जिसे तालिका बनाते समय विशेषता या डेटा प्रकार परिभाषाओं की आवश्यकता नहीं होती है। इसके लिए केवल RDBMS के विपरीत एक प्राथमिक कुंजी विशेषता डेटा प्रकार की आवश्यकता होती है, जिसमें तालिका निर्माण पर स्तंभ डेटा प्रकारों की आवश्यकता होती है।
Scalars
Numbers - वे 38 अंकों तक सीमित हैं, और या तो सकारात्मक, नकारात्मक या शून्य हैं।
String - वे यूटीएफ -8 का उपयोग करते हुए यूनिकोड हैं, न्यूनतम लंबाई> 0 और अधिकतम 400KB।
Binary- वे किसी भी द्विआधारी डेटा, जैसे, एन्क्रिप्टेड डेटा, चित्र और संपीड़ित पाठ को संग्रहीत करते हैं। डायनामोबीडी अपने बाइट्स को अहस्ताक्षरित मानता है।
Boolean - वे सही या गलत स्टोर करते हैं।
Null - वे एक अज्ञात या अपरिभाषित स्थिति का प्रतिनिधित्व करते हैं।
डाक्यूमेंट
List - यह मूल्य संग्रह का आदेश दिया भंडार, और वर्ग ([...]) कोष्ठक का उपयोग करता है।
Map - यह अनियंत्रित नाम-मूल्य जोड़ी संग्रह को संग्रहीत करता है, और घुंघराले ({...}) ब्रेसिज़ का उपयोग करता है।
सेट
सेट में एक ही प्रकार के तत्व होने चाहिए चाहे संख्या, स्ट्रिंग या बाइनरी। सेट पर रखी गई एकमात्र सीमा में 400KB आइटम आकार सीमा और प्रत्येक तत्व अद्वितीय है।
एक्शन डेटा प्रकार
DynamoDB API क्रियाओं द्वारा उपयोग किए जाने वाले विभिन्न डेटा प्रकार रखता है। आप निम्नलिखित प्रमुख प्रकारों के चयन की समीक्षा कर सकते हैं -
AttributeDefinition - यह कुंजी तालिका और सूचकांक स्कीमा का प्रतिनिधित्व करता है।
Capacity - यह एक तालिका या सूचकांक द्वारा खपत थ्रूपुट की मात्रा का प्रतिनिधित्व करता है।
CreateGlobalSecondaryIndexAction - यह तालिका में जोड़े गए एक नए वैश्विक माध्यमिक सूचकांक का प्रतिनिधित्व करता है।
LocalSecondaryIndex - यह स्थानीय माध्यमिक सूचकांक गुणों का प्रतिनिधित्व करता है।
ProvisionedThroughput - यह एक सूचकांक या तालिका के लिए प्रावधानित थ्रूपुट का प्रतिनिधित्व करता है।
PutRequest - यह PutItem अनुरोधों का प्रतिनिधित्व करता है।
TableDescription - यह तालिका गुणों का प्रतिनिधित्व करता है।
समर्थित जावा डेटाटाइप्स
DynamoDB जावा के लिए आदिम डेटा प्रकार, सेट संग्रह और मनमाने प्रकार के लिए समर्थन प्रदान करता है।
एक तालिका बनाना आम तौर पर तालिका को स्पॉइंग करना, इसे नाम देना, इसकी प्राथमिक प्रमुख विशेषताओं को स्थापित करना और विशेषता डेटा प्रकार सेट करना शामिल है।
इन कार्यों को करने के लिए GUI कंसोल, जावा या किसी अन्य विकल्प का उपयोग करें।
GUI कंसोल का उपयोग करके तालिका बनाएँ
कंसोल पर पहुँच कर एक तालिका बनाएँ https://console.aws.amazon.com/dynamodb। फिर “Create Table” विकल्प चुनें।
हमारा उदाहरण उत्पाद जानकारी के साथ आबादी वाली तालिका बनाता है, जिसमें आईडी नंबर (संख्यात्मक विशेषता) द्वारा पहचाने जाने वाले अद्वितीय विशेषताओं के उत्पाद होते हैं। मेंCreate Tableस्क्रीन, तालिका नाम फ़ील्ड के भीतर तालिका नाम दर्ज करें; विभाजन कुंजी क्षेत्र के भीतर प्राथमिक कुंजी (आईडी) दर्ज करें; और डेटा प्रकार के लिए "संख्या" दर्ज करें।
सभी जानकारी दर्ज करने के बाद, चयन करें Create।
जावा का उपयोग करके तालिका बनाएं
उसी तालिका को बनाने के लिए जावा का उपयोग करें। इसकी प्राथमिक कुंजी में निम्नलिखित दो विशेषताएं हैं -
ID - एक विभाजन कुंजी, और ScalarAttributeType का उपयोग करें N, अर्थ संख्या।
Nomenclature - एक सॉर्ट कुंजी, और ScalarAttributeType का उपयोग करें S, अर्थ स्ट्रिंग।
जावा का उपयोग करता है createTable methodएक मेज उत्पन्न करने के लिए; और कॉल के भीतर, तालिका का नाम, प्राथमिक कुंजी विशेषताएँ, और विशेषता डेटा प्रकार निर्दिष्ट हैं।
आप निम्न उदाहरण की समीक्षा कर सकते हैं -
import java.util.Arrays;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.model.AttributeDefinition;
import com.amazonaws.services.dynamodbv2.model.KeySchemaElement;
import com.amazonaws.services.dynamodbv2.model.KeyType;
import com.amazonaws.services.dynamodbv2.model.ProvisionedThroughput;
import com.amazonaws.services.dynamodbv2.model.ScalarAttributeType;
public class ProductsCreateTable {
public static void main(String[] args) throws Exception {
AmazonDynamoDBClient client = new AmazonDynamoDBClient()
.withEndpoint("http://localhost:8000");
DynamoDB dynamoDB = new DynamoDB(client);
String tableName = "Products";
try {
System.out.println("Creating the table, wait...");
Table table = dynamoDB.createTable (tableName,
Arrays.asList (
new KeySchemaElement("ID", KeyType.HASH), // the partition key
// the sort key
new KeySchemaElement("Nomenclature", KeyType.RANGE)
),
Arrays.asList (
new AttributeDefinition("ID", ScalarAttributeType.N),
new AttributeDefinition("Nomenclature", ScalarAttributeType.S)
),
new ProvisionedThroughput(10L, 10L)
);
table.waitForActive();
System.out.println("Table created successfully. Status: " +
table.getDescription().getTableStatus());
} catch (Exception e) {
System.err.println("Cannot create the table: ");
System.err.println(e.getMessage());
}
}
}
उपरोक्त उदाहरण में, समापन बिंदु पर ध्यान दें: .withEndpoint।
यह लोकलहोस्ट के इस्तेमाल से लोकल इंस्टाल के इस्तेमाल का संकेत देता है। इसके अलावा, नोट करेंProvisionedThroughput parameter, जो स्थानीय स्थापित उपेक्षा करता है।
तालिका को आम तौर पर लोड करना एक स्रोत फ़ाइल बनाने के लिए होता है, यह सुनिश्चित करता है कि स्रोत फ़ाइल डायनामोडीबी के साथ एक सिंटैक्स के अनुरूप हो, स्रोत फ़ाइल को गंतव्य पर भेज रही है, और फिर एक सफल आबादी की पुष्टि करता है।
कार्य करने के लिए GUI कंसोल, जावा या किसी अन्य विकल्प का उपयोग करें।
जीयूआई कंसोल का उपयोग करके लोड टेबल
कमांड लाइन और कंसोल के संयोजन का उपयोग करके डेटा लोड करें। आप कई तरीकों से डेटा लोड कर सकते हैं, जिनमें से कुछ इस प्रकार हैं -
- सांत्वना
- कमांड लाइन
- कोड और भी
- डेटा पाइपलाइन (ट्यूटोरियल में बाद में चर्चा की गई सुविधा)
हालाँकि, गति के लिए, यह उदाहरण शेल और कंसोल दोनों का उपयोग करता है। सबसे पहले, स्रोत डेटा को निम्नलिखित सिंटैक्स के साथ गंतव्य में लोड करें -
aws dynamodb batch-write-item -–request-items file://[filename]
उदाहरण के लिए -
aws dynamodb batch-write-item -–request-items file://MyProductData.json
कंसोल पर पहुँच कर ऑपरेशन की सफलता की जाँच करें -
https://console.aws.amazon.com/dynamodb
चुनें Tables नेविगेशन फलक से, और तालिका सूची से गंतव्य तालिका का चयन करें।
को चुनिए Itemsटैब उस डेटा की जांच करने के लिए जिसे आपने तालिका को पॉप्युलेट करने के लिए उपयोग किया था। चुनते हैंCancel तालिका सूची में वापस आने के लिए।
जावा का उपयोग करके लोड टेबल
जावा को पहले सोर्स फाइल बनाकर रोजगार दें। हमारी स्रोत फ़ाइल JSON प्रारूप का उपयोग करती है। प्रत्येक उत्पाद में दो प्राथमिक मुख्य गुण होते हैं (आईडी और नामकरण) और एक JSON मानचित्र (स्टेट) -
[
{
"ID" : ... ,
"Nomenclature" : ... ,
"Stat" : { ... }
},
{
"ID" : ... ,
"Nomenclature" : ... ,
"Stat" : { ... }
},
...
]
आप निम्न उदाहरण की समीक्षा कर सकते हैं -
{
"ID" : 122,
"Nomenclature" : "Particle Blaster 5000",
"Stat" : {
"Manufacturer" : "XYZ Inc.",
"sales" : "1M+",
"quantity" : 500,
"img_src" : "http://www.xyz.com/manuals/particleblaster5000.jpg",
"description" : "A laser cutter used in plastic manufacturing."
}
}
अगला चरण आपके एप्लिकेशन द्वारा उपयोग की गई निर्देशिका में फ़ाइल को रखना है।
जावा मुख्य रूप से उपयोग करता है putItem तथा path methods लोड करने के लिए।
आप फ़ाइल को संसाधित करने और उसे लोड करने के लिए निम्न कोड उदाहरण की समीक्षा कर सकते हैं -
import java.io.File;
import java.util.Iterator;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper
import com.fasterxml.jackson.databind.node.ObjectNode;
public class ProductsLoadData {
public static void main(String[] args) throws Exception {
AmazonDynamoDBClient client = new AmazonDynamoDBClient()
.withEndpoint("http://localhost:8000");
DynamoDB dynamoDB = new DynamoDB(client);
Table table = dynamoDB.getTable("Products");
JsonParser parser = new JsonFactory()
.createParser(new File("productinfo.json"));
JsonNode rootNode = new ObjectMapper().readTree(parser);
Iterator<JsonNode> iter = rootNode.iterator();
ObjectNode currentNode;
while (iter.hasNext()) {
currentNode = (ObjectNode) iter.next();
int ID = currentNode.path("ID").asInt();
String Nomenclature = currentNode.path("Nomenclature").asText();
try {
table.putItem(new Item()
.withPrimaryKey("ID", ID, "Nomenclature", Nomenclature)
.withJSON("Stat", currentNode.path("Stat").toString()));
System.out.println("Successful load: " + ID + " " + Nomenclature);
} catch (Exception e) {
System.err.println("Cannot add product: " + ID + " " + Nomenclature);
System.err.println(e.getMessage());
break;
}
}
parser.close();
}
}
मुख्य रूप से एक तालिका का चयन करने के लिए एक तालिका का चयन करने की आवश्यकता होती है, एक विभाजन कुंजी निर्दिष्ट करता है, और क्वेरी निष्पादित करता है; सेकंडरी इंडेक्स का उपयोग करने और स्कैन संचालन के माध्यम से गहरी छानने के विकल्पों के साथ।
कार्य करने के लिए GUI कंसोल, जावा या किसी अन्य विकल्प का उपयोग करें।
GUI कंसोल का उपयोग करके क्वेरी तालिका
पहले से बनाई गई तालिकाओं का उपयोग करके कुछ सरल क्वेरी करें। सबसे पहले, कंसोल को खोलेंhttps://console.aws.amazon.com/dynamodb
चुनें Tables नेविगेशन फलक से और चुनें Replyतालिका सूची से। फिर का चयन करेंItems लोड किए गए डेटा को देखने के लिए टैब।
नीचे डेटा फ़िल्टरिंग लिंक ("स्कैन: [टेबल] जवाब") का चयन करें Create Item बटन।
फ़िल्टरिंग स्क्रीन में, ऑपरेशन के लिए क्वेरी का चयन करें। उचित विभाजन कुंजी मान दर्ज करें, और क्लिक करेंStart।
Reply तालिका फिर मिलान आइटम लौटाती है।
जावा का उपयोग करके क्वेरी तालिका
डेटा पुनर्प्राप्ति ऑपरेशन करने के लिए जावा में क्वेरी विधि का उपयोग करें। यह वैकल्पिक के रूप में कुंजी के साथ विभाजन कुंजी मूल्य निर्दिष्ट करने की आवश्यकता है।
पहले एक जावा क्वैरी बनाकर कोड बनाएं querySpec objectमापदंडों का वर्णन। फिर ऑब्जेक्ट को क्वेरी विधि से पास करें। हम पिछले उदाहरणों से विभाजन कुंजी का उपयोग करते हैं।
आप निम्न उदाहरण की समीक्षा कर सकते हैं -
import java.util.HashMap;
import java.util.Iterator;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.ItemCollection;
import com.amazonaws.services.dynamodbv2.document.QueryOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.spec.QuerySpec;
import com.amazonaws.services.dynamodbv2.document.utils.NameMap;
public class ProductsQuery {
public static void main(String[] args) throws Exception {
AmazonDynamoDBClient client = new AmazonDynamoDBClient()
.withEndpoint("http://localhost:8000");
DynamoDB dynamoDB = new DynamoDB(client);
Table table = dynamoDB.getTable("Products");
HashMap<String, String> nameMap = new HashMap<String, String>();
nameMap.put("#ID", "ID");
HashMap<String, Object> valueMap = new HashMap<String, Object>();
valueMap.put(":xxx", 122);
QuerySpec querySpec = new QuerySpec()
.withKeyConditionExpression("#ID = :xxx")
.withNameMap(new NameMap().with("#ID", "ID"))
.withValueMap(valueMap);
ItemCollection<QueryOutcome> items = null;
Iterator<Item> iterator = null;
Item item = null;
try {
System.out.println("Product with the ID 122");
items = table.query(querySpec);
iterator = items.iterator();
while (iterator.hasNext()) {
item = iterator.next();
System.out.println(item.getNumber("ID") + ": "
+ item.getString("Nomenclature"));
}
} catch (Exception e) {
System.err.println("Cannot find products with the ID number 122");
System.err.println(e.getMessage());
}
}
}
ध्यान दें कि क्वेरी विभाजन कुंजी का उपयोग करती है, हालांकि, द्वितीयक सूचकांक प्रश्नों के लिए एक और विकल्प प्रदान करते हैं। उनका लचीलापन गैर-प्रमुख विशेषताओं की क्वेरी करने की अनुमति देता है, एक विषय जिस पर बाद में इस ट्यूटोरियल में चर्चा की जाएगी।
स्कैन विधि सभी तालिका डेटा को इकट्ठा करके पुनर्प्राप्ति संचालन का भी समर्थन करती है। optional .withFilterExpression परिणामों में प्रदर्शित होने से निर्दिष्ट मानदंडों के बाहर आइटम को रोकता है।
बाद में इस ट्यूटोरियल में हम चर्चा करेंगे scanningविस्तार से। अब, निम्नलिखित उदाहरण पर एक नज़र डालें -
import java.util.Iterator;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.ItemCollection;
import com.amazonaws.services.dynamodbv2.document.ScanOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.spec.ScanSpec;
import com.amazonaws.services.dynamodbv2.document.utils.NameMap;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
public class ProductsScan {
public static void main(String[] args) throws Exception {
AmazonDynamoDBClient client = new AmazonDynamoDBClient()
.withEndpoint("http://localhost:8000");
DynamoDB dynamoDB = new DynamoDB(client);
Table table = dynamoDB.getTable("Products");
ScanSpec scanSpec = new ScanSpec()
.withProjectionExpression("#ID, Nomenclature , stat.sales")
.withFilterExpression("#ID between :start_id and :end_id")
.withNameMap(new NameMap().with("#ID", "ID"))
.withValueMap(new ValueMap().withNumber(":start_id", 120)
.withNumber(":end_id", 129));
try {
ItemCollection<ScanOutcome> items = table.scan(scanSpec);
Iterator<Item> iter = items.iterator();
while (iter.hasNext()) {
Item item = iter.next();
System.out.println(item.toString());
}
} catch (Exception e) {
System.err.println("Cannot perform a table scan:");
System.err.println(e.getMessage());
}
}
}
इस अध्याय में, हम इस बारे में चर्चा करेंगे कि कैसे हम एक तालिका को हटा सकते हैं और एक तालिका को हटाने के विभिन्न तरीकों को भी।
टेबल विलोपन एक सरल ऑपरेशन है जिसमें टेबल नाम की तुलना में थोड़ा अधिक की आवश्यकता होती है। इस कार्य को करने के लिए GUI कंसोल, जावा, या किसी अन्य विकल्प का उपयोग करें।
GUI कंसोल का उपयोग करके तालिका हटाएं
पहले कंसोल पर पहुंचकर एक डिलीट ऑपरेशन करें -
https://console.aws.amazon.com/dynamodb।
चुनें Tables नेविगेशन फलक से, और तालिका सूची से हटाने के लिए वांछित तालिका का चयन करें जैसा कि निम्नलिखित विवरण में दिखाया गया है।
अंत में, चयन करें Delete Table। डिलीट टेबल चुनने के बाद, एक पुष्टिकरण दिखाई देता है। आपकी तालिका तब हटा दी गई है।
जावा का उपयोग करके तालिका हटाएं
उपयोग deleteएक मेज को हटाने के लिए विधि। अवधारणा को बेहतर ढंग से समझाने के लिए एक उदाहरण नीचे दिया गया है।
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Table;
public class ProductsDeleteTable {
public static void main(String[] args) throws Exception {
AmazonDynamoDBClient client = new AmazonDynamoDBClient()
.withEndpoint("http://localhost:8000");
DynamoDB dynamoDB = new DynamoDB(client);
Table table = dynamoDB.getTable("Products");
try {
System.out.println("Performing table delete, wait...");
table.delete();
table.waitForDelete();
System.out.print("Table successfully deleted.");
} catch (Exception e) {
System.err.println("Cannot perform table delete: ");
System.err.println(e.getMessage());
}
}
}
डायनमोडी टेबल हेरफेर, डेटा रीड्स और डेटा संशोधन के लिए शक्तिशाली एपीआई टूल का एक विस्तृत सेट प्रदान करता है।
अमेज़ॅन का उपयोग करने की सिफारिश करता है AWS SDKs(उदाहरण के लिए, जावा एसडीके) निम्न-स्तरीय एपीआई को कॉल करने के बजाय। लाइब्रेरी निम्न स्तर के एपीआई के साथ सीधे अनावश्यक संपर्क करती हैं। पुस्तकालय प्रमाणीकरण, क्रमांकन और कनेक्शन जैसे सामान्य कार्यों को सरल बनाते हैं।
तालिकाओं में हेरफेर करें
डायनेमोडी टेबल प्रबंधन के लिए पांच निम्न स्तर की कार्रवाई प्रदान करता है -
CreateTable- यह एक तालिका बनाता है और इसमें उपयोगकर्ता द्वारा निर्धारित थ्रूपुट शामिल होता है। आपको एक प्राथमिक कुंजी सेट करने की आवश्यकता है, चाहे समग्र या सरल। यह एक या कई सेकंडरी इंडेक्स की भी अनुमति देता है।
ListTables - यह वर्तमान AWS उपयोगकर्ता के खाते में सभी तालिकाओं की एक सूची प्रदान करता है और उनके समापन बिंदु से बंधा होता है।
UpdateTable - यह थ्रूपुट और ग्लोबल सेकेंडरी इंडेक्स थ्रूपुट को बदल देता है।
DescribeTable- यह तालिका मेटाडेटा प्रदान करता है; उदाहरण के लिए, राज्य, आकार और सूचकांक।
DeleteTable - यह केवल टेबल और उसके सूचकांकों को मिटा देता है।
डेटा पढ़ें
DynamoDB डेटा पढ़ने के लिए चार निम्न-स्तरीय क्रियाएं प्रदान करता है -
GetItem- यह एक प्राथमिक कुंजी को स्वीकार करता है और संबंधित आइटम की विशेषताओं को लौटाता है। यह इसकी डिफ़ॉल्ट रूप से अंत में लगातार पढ़ने की सेटिंग में परिवर्तन की अनुमति देता है।
BatchGetItem- यह एक या एक से अधिक तालिकाओं के विकल्प के साथ प्राथमिक कुंजी के माध्यम से कई मदों पर कई GetItem अनुरोधों को निष्पादित करता है। इसका रिटर्न 100 से अधिक नहीं है और इसे 16 एमबी से कम रहना चाहिए। यह अंततः सुसंगत और दृढ़ता से सुसंगत पठन की अनुमति देता है।
Scan- यह सभी टेबल आइटम को पढ़ता है और अंततः एक सुसंगत परिणाम सेट का उत्पादन करता है। आप शर्तों के माध्यम से परिणाम फ़िल्टर कर सकते हैं। यह एक सूचकांक के उपयोग से बचा जाता है और संपूर्ण तालिका को स्कैन करता है, इसलिए पूर्वानुमान की आवश्यकता वाले प्रश्नों के लिए इसका उपयोग न करें।
Query- यह एक एकल या कई तालिका आइटम या द्वितीयक सूचकांक आइटम लौटाता है। यह विभाजन कुंजी के लिए एक निर्दिष्ट मान का उपयोग करता है, और तुलना ऑपरेटरों के संकीर्ण दायरे के उपयोग की अनुमति देता है। इसमें दोनों प्रकार की स्थिरता के लिए समर्थन शामिल है, और प्रत्येक प्रतिक्रिया आकार में 1MB की सीमा का पालन करती है।
डेटा संशोधित करें
डायनेमोबीडी डेटा संशोधन के लिए चार निम्न-स्तरीय क्रियाएं प्रदान करता है -
PutItem- यह एक नया आइटम बनाता है या मौजूदा वस्तुओं को बदल देता है। डिफ़ॉल्ट रूप से समान प्राथमिक कुंजियों की खोज पर, यह आइटम को बदल देता है। सशर्त ऑपरेटर आपको डिफ़ॉल्ट के आसपास काम करने की अनुमति देते हैं, और केवल कुछ शर्तों के तहत आइटम को प्रतिस्थापित करते हैं।
BatchWriteItem- यह दोनों कई PutItem और DeleteItem अनुरोधों, और कई तालिकाओं को निष्पादित करता है। यदि एक अनुरोध विफल हो जाता है, तो यह पूरे ऑपरेशन को प्रभावित नहीं करता है। इसकी टोपी 25 वस्तुओं, और आकार में 16 एमबी पर बैठती है।
UpdateItem - यह मौजूदा आइटम विशेषताओं को बदलता है, और केवल कुछ शर्तों के तहत अपडेट निष्पादित करने के लिए सशर्त ऑपरेटरों के उपयोग की अनुमति देता है।
DeleteItem - यह एक आइटम को मिटाने के लिए प्राथमिक कुंजी का उपयोग करता है, और सशर्त ऑपरेटरों के उपयोग को हटाने की शर्तों को निर्दिष्ट करने की भी अनुमति देता है।
DynamoDB में एक आइटम बनाना मुख्य रूप से आइटम और विशेषता विनिर्देश, और निर्दिष्ट शर्तों का विकल्प होता है। प्रत्येक आइटम विशेषताओं के एक सेट के रूप में मौजूद है, जिसमें प्रत्येक विशेषता को एक निश्चित प्रकार के मूल्य के नाम और असाइन किया गया है।
मान प्रकार में स्केलर, दस्तावेज़ या सेट शामिल हैं। आइटम 400KB आकार की सीमा को वहन करते हैं, उस सीमा के भीतर फिटिंग करने में सक्षम किसी भी राशि की संभावना के साथ। नाम और मूल्य आकार (बाइनरी और UTF-8 लंबाई) आइटम का आकार निर्धारित करते हैं। छोटी विशेषता नाम का उपयोग करके आइटम आकार को कम करना है।
Note- आपको सभी प्राथमिक कुंजी विशेषताओं को निर्दिष्ट करना होगा, प्राथमिक कुंजी के साथ केवल विभाजन कुंजी की आवश्यकता होगी; और कम्पोज़िट कीज़ को विभाजन और सॉर्ट कुंजी दोनों की आवश्यकता होती है।
इसके अलावा, याद रखें कि टेबल में कोई पूर्वनिर्धारित स्कीमा नहीं है। आप एक तालिका में नाटकीय रूप से अलग डेटासेट स्टोर कर सकते हैं।
इस कार्य को करने के लिए GUI कंसोल, जावा या किसी अन्य टूल का उपयोग करें।
GUI कंसोल का उपयोग करके आइटम कैसे बनाएं?
कंसोल पर नेविगेट करें। बाईं ओर नेविगेशन फलक में, का चयन करेंTables। गंतव्य के रूप में उपयोग के लिए तालिका का नाम चुनें, और फिर चुनेंItems निम्न स्क्रीनशॉट में दिखाया गया टैब।
चुनते हैं Create Item। आइटम बनाएँ स्क्रीन आवश्यक विशेषता मान दर्ज करने के लिए एक इंटरफ़ेस प्रदान करता है। किसी भी द्वितीयक सूचक को भी दर्ज किया जाना चाहिए।
यदि आपको अधिक विशेषताओं की आवश्यकता है, तो बाईं ओर स्थित एक्शन मेनू चुनें Message। फिर सेलेक्ट करेंAppend, और वांछित डेटा प्रकार।
सभी आवश्यक जानकारी दर्ज करने के बाद, चयन करें Save आइटम जोड़ने के लिए।
आइटम निर्माण में जावा का उपयोग कैसे करें?
आइटम निर्माण परिचालनों में जावा का उपयोग करना डायनमोडीबी श्रेणी उदाहरण, टेबल क्लास उदाहरण, आइटम वर्ग उदाहरण, और आपके द्वारा बनाई गई आइटम की प्राथमिक कुंजी और विशेषताओं को निर्दिष्ट करना शामिल है। फिर अपने नए आइटम को putItem विधि के साथ जोड़ें।
उदाहरण
DynamoDB dynamoDB = new DynamoDB (new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("ProductList");
// Spawn a related items list
List<Number> RELItems = new ArrayList<Number>();
RELItems.add(123);
RELItems.add(456);
RELItems.add(789);
//Spawn a product picture map
Map<String, String> photos = new HashMap<String, String>();
photos.put("Anterior", "http://xyz.com/products/101_front.jpg");
photos.put("Posterior", "http://xyz.com/products/101_back.jpg");
photos.put("Lateral", "http://xyz.com/products/101_LFTside.jpg");
//Spawn a product review map
Map<String, List<String>> prodReviews = new HashMap<String, List<String>>();
List<String> fiveStarRVW = new ArrayList<String>();
fiveStarRVW.add("Shocking high performance.");
fiveStarRVW.add("Unparalleled in its market.");
prodReviews.put("5 Star", fiveStarRVW);
List<String> oneStarRVW = new ArrayList<String>();
oneStarRVW.add("The worst offering in its market.");
prodReviews.put("1 Star", oneStarRVW);
// Generate the item
Item item = new Item()
.withPrimaryKey("Id", 101)
.withString("Nomenclature", "PolyBlaster 101")
.withString("Description", "101 description")
.withString("Category", "Hybrid Power Polymer Cutter")
.withString("Make", "Brand – XYZ")
.withNumber("Price", 50000)
.withString("ProductCategory", "Laser Cutter")
.withBoolean("Availability", true)
.withNull("Qty")
.withList("ItemsRelated", RELItems)
.withMap("Images", photos)
.withMap("Reviews", prodReviews);
// Add item to the table
PutItemOutcome outcome = table.putItem(item);
आप निम्नलिखित बड़े उदाहरण को भी देख सकते हैं।
Note- निम्नलिखित नमूना पहले से निर्मित डेटा स्रोत मान सकते हैं। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
निम्न नमूना भी ग्रहण आईडीई, एक एडब्ल्यूएस क्रेडेंशियल्स फ़ाइल और एक एडब्ल्यूएस जावा प्रोजेक्ट के भीतर एडब्ल्यूएस टूलकिट का उपयोग करता है।
package com.amazonaws.codesamples.document;
import java.io.IOException;
import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DeleteItemOutcome;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.UpdateItemOutcome;
import com.amazonaws.services.dynamodbv2.document.spec.DeleteItemSpec;
import com.amazonaws.services.dynamodbv2.document.spec.UpdateItemSpec;
import com.amazonaws.services.dynamodbv2.document.utils.NameMap;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
import com.amazonaws.services.dynamodbv2.model.ReturnValue;
public class CreateItemOpSample {
static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient (
new ProfileCredentialsProvider()));
static String tblName = "ProductList";
public static void main(String[] args) throws IOException {
createItems();
retrieveItem();
// Execute updates
updateMultipleAttributes();
updateAddNewAttribute();
updateExistingAttributeConditionally();
// Item deletion
deleteItem();
}
private static void createItems() {
Table table = dynamoDB.getTable(tblName);
try {
Item item = new Item()
.withPrimaryKey("ID", 303)
.withString("Nomenclature", "Polymer Blaster 4000")
.withStringSet( "Manufacturers",
new HashSet<String>(Arrays.asList("XYZ Inc.", "LMNOP Inc.")))
.withNumber("Price", 50000)
.withBoolean("InProduction", true)
.withString("Category", "Laser Cutter");
table.putItem(item);
item = new Item()
.withPrimaryKey("ID", 313)
.withString("Nomenclature", "Agitatatron 2000")
.withStringSet( "Manufacturers",
new HashSet<String>(Arrays.asList("XYZ Inc,", "CDE Inc.")))
.withNumber("Price", 40000)
.withBoolean("InProduction", true)
.withString("Category", "Agitator");
table.putItem(item);
} catch (Exception e) {
System.err.println("Cannot create items.");
System.err.println(e.getMessage());
}
}
}
DynamoDB में किसी आइटम को प्राप्त करने के लिए GetItem का उपयोग करना पड़ता है, और तालिका का नाम और आइटम प्राथमिक कुंजी निर्दिष्ट करना होता है। एक हिस्से को छोड़ने के बजाय एक पूर्ण प्राथमिक कुंजी शामिल करना सुनिश्चित करें।
उदाहरण के लिए, मिश्रित कुंजी की सॉर्ट कुंजी को छोड़ना।
GetItem व्यवहार तीन चूक के अनुरूप है -
- यह अंततः सुसंगत रीड के रूप में निष्पादित होता है।
- यह सभी गुण प्रदान करता है।
- यह इसकी क्षमता इकाई की खपत का विवरण नहीं देता है।
ये पैरामीटर आपको डिफ़ॉल्ट GetItem व्यवहार को ओवरराइड करने की अनुमति देते हैं।
एक आइटम पुनर्प्राप्त करें
DynamoDB कई सर्वरों पर वस्तुओं की कई प्रतियों को बनाए रखने के माध्यम से विश्वसनीयता सुनिश्चित करता है। प्रत्येक सफल लेखन इन प्रतियों को बनाता है, लेकिन निष्पादित करने के लिए पर्याप्त समय लेता है; अंत में सुसंगत अर्थ। इसका मतलब है कि आप किसी आइटम को लिखने के तुरंत बाद पढ़ने का प्रयास नहीं कर सकते।
आप GetItem के डिफ़ॉल्ट अंततः सुसंगत रीड को बदल सकते हैं, हालांकि, अधिक वर्तमान डेटा की लागत अधिक क्षमता इकाइयों की खपत बनी हुई है; विशेष रूप से, दो बार जितना। नोट डायनॉम्बीडी आमतौर पर एक सेकंड के भीतर हर कॉपी में स्थिरता प्राप्त करता है।
इस कार्य को करने के लिए आप GUI कंसोल, जावा या किसी अन्य टूल का उपयोग कर सकते हैं।
जावा का उपयोग करके आइटम पुनर्प्राप्ति
आइटम पुनर्प्राप्ति कार्यों में जावा का उपयोग करने के लिए डायनमोबडी क्लास इंस्टेंस, टेबल क्लास इंस्टेंस बनाने और टेबल इंस्टेंस के गेट इट विधि को कॉल करने की आवश्यकता होती है। फिर आइटम की प्राथमिक कुंजी निर्दिष्ट करें।
आप निम्न उदाहरण की समीक्षा कर सकते हैं -
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("ProductList");
Item item = table.getItem("IDnum", 109);
कुछ मामलों में, आपको इस ऑपरेशन के लिए मापदंडों को निर्दिष्ट करने की आवश्यकता है।
निम्नलिखित उदाहरण का उपयोग करता है .withProjectionExpression तथा GetItemSpec पुनर्प्राप्ति विनिर्देशों के लिए -
GetItemSpec spec = new GetItemSpec()
.withPrimaryKey("IDnum", 122)
.withProjectionExpression("IDnum, EmployeeName, Department")
.withConsistentRead(true);
Item item = table.getItem(spec);
System.out.println(item.toJSONPretty());
बेहतर समझ के लिए आप निम्नलिखित बड़े उदाहरणों की भी समीक्षा कर सकते हैं।
Note- निम्नलिखित नमूना पहले से निर्मित डेटा स्रोत मान सकते हैं। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
यह नमूना ग्रहण आईडीई, एक एडब्ल्यूएस क्रेडेंशियल फ़ाइल और एडब्ल्यूएस टूलकिट को एक्लिप्स एईए जावा प्रोजेक्ट के भीतर भी उपयोग करता है।
package com.amazonaws.codesamples.document;
import java.io.IOException
import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DeleteItemOutcome;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.UpdateItemOutcome;
import com.amazonaws.services.dynamodbv2.document.spec.DeleteItemSpec;
import com.amazonaws.services.dynamodbv2.document.spec.UpdateItemSpec;
import com.amazonaws.services.dynamodbv2.document.utils.NameMap;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
import com.amazonaws.services.dynamodbv2.model.ReturnValue;
public class GetItemOpSample {
static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
static String tblName = "ProductList";
public static void main(String[] args) throws IOException {
createItems();
retrieveItem();
// Execute updates
updateMultipleAttributes();
updateAddNewAttribute();
updateExistingAttributeConditionally();
// Item deletion
deleteItem();
}
private static void createItems() {
Table table = dynamoDB.getTable(tblName);
try {
Item item = new Item()
.withPrimaryKey("ID", 303)
.withString("Nomenclature", "Polymer Blaster 4000")
.withStringSet( "Manufacturers",
new HashSet<String>(Arrays.asList("XYZ Inc.", "LMNOP Inc.")))
.withNumber("Price", 50000)
.withBoolean("InProduction", true)
.withString("Category", "Laser Cutter");
table.putItem(item);
item = new Item()
.withPrimaryKey("ID", 313)
.withString("Nomenclature", "Agitatatron 2000")
.withStringSet( "Manufacturers",
new HashSet<String>(Arrays.asList("XYZ Inc,", "CDE Inc.")))
.withNumber("Price", 40000)
.withBoolean("InProduction", true)
.withString("Category", "Agitator");
table.putItem(item);
} catch (Exception e) {
System.err.println("Cannot create items.");
System.err.println(e.getMessage());
}
}
private static void retrieveItem() {
Table table = dynamoDB.getTable(tableName);
try {
Item item = table.getItem("ID", 303, "ID, Nomenclature, Manufacturers", null);
System.out.println("Displaying retrieved items...");
System.out.println(item.toJSONPretty());
} catch (Exception e) {
System.err.println("Cannot retrieve items.");
System.err.println(e.getMessage());
}
}
}
डायनमोबी में एक आइटम को अपडेट करना मुख्य रूप से आइटम के लिए पूर्ण प्राथमिक कुंजी और तालिका नाम निर्दिष्ट करना है। इसमें आपके द्वारा संशोधित प्रत्येक विशेषता के लिए एक नए मूल्य की आवश्यकता होती है। ऑपरेशन का उपयोग करता हैUpdateItem, जो मौजूदा वस्तुओं को संशोधित करता है या लापता वस्तु की खोज पर बनाता है।
अद्यतनों में, आप परिचालन से पहले और बाद में मूल और नए मूल्यों को प्रदर्शित करके परिवर्तनों को ट्रैक करना चाह सकते हैं। UpdateItem का उपयोग करता हैReturnValues इसे प्राप्त करने के लिए पैरामीटर।
Note - ऑपरेशन क्षमता इकाई की खपत की रिपोर्ट नहीं करता है, लेकिन आप इसका उपयोग कर सकते हैं ReturnConsumedCapacity पैरामीटर।
इस कार्य को करने के लिए GUI कंसोल, जावा या किसी अन्य टूल का उपयोग करें।
GUI टूल्स का उपयोग करके आइटम कैसे अपडेट करें?
कंसोल पर नेविगेट करें। बाईं ओर नेविगेशन फलक में, का चयन करेंTables। आवश्यक तालिका चुनें, और तब चुनेंItems टैब।
किसी अद्यतन के लिए वांछित आइटम चुनें, और चुनें Actions | Edit।
में आवश्यक किसी भी विशेषता या मूल्यों को संशोधित करें Edit Item खिड़की।
जावा का उपयोग करके आइटम अपडेट करें
आइटम अद्यतन परिचालनों में जावा का उपयोग करने के लिए एक टेबल क्लास उदाहरण बनाने और उसके कॉल करने की आवश्यकता होती है updateItemतरीका। तब आप आइटम की प्राथमिक कुंजी निर्दिष्ट करते हैं, और एक प्रदान करते हैंUpdateExpression विवरण विशेषताओं में संशोधन।
निम्नलिखित उसी का एक उदाहरण है -
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("ProductList");
Map<String, String> expressionAttributeNames = new HashMap<String, String>();
expressionAttributeNames.put("#M", "Make");
expressionAttributeNames.put("#P", "Price
expressionAttributeNames.put("#N", "ID");
Map<String, Object> expressionAttributeValues = new HashMap<String, Object>();
expressionAttributeValues.put(":val1",
new HashSet<String>(Arrays.asList("Make1","Make2")));
expressionAttributeValues.put(":val2", 1); //Price
UpdateItemOutcome outcome = table.updateItem(
"internalID", // key attribute name
111, // key attribute value
"add #M :val1 set #P = #P - :val2 remove #N", // UpdateExpression
expressionAttributeNames,
expressionAttributeValues);
updateItem विधि शर्तों को निर्दिष्ट करने की भी अनुमति देती है, जिसे निम्नलिखित उदाहरण में देखा जा सकता है -
Table table = dynamoDB.getTable("ProductList");
Map<String, String> expressionAttributeNames = new HashMap<String, String>();
expressionAttributeNames.put("#P", "Price");
Map<String, Object> expressionAttributeValues = new HashMap<String, Object>();
expressionAttributeValues.put(":val1", 44); // change Price to 44
expressionAttributeValues.put(":val2", 15); // only if currently 15
UpdateItemOutcome outcome = table.updateItem (new PrimaryKey("internalID",111),
"set #P = :val1", // Update
"#P = :val2", // Condition
expressionAttributeNames,
expressionAttributeValues);
काउंटरों का उपयोग करके आइटम अपडेट करें
डायनॉम्बिक परमाणु काउंटरों की अनुमति देता है, जिसका अर्थ है कि अन्य अनुरोधों को प्रभावित किए बिना इनटर्मेंट / इंक्रीमेंट विशेषता मानों को अपडेट करना; इसके अलावा, काउंटर हमेशा अद्यतन करते हैं।
निम्नलिखित एक उदाहरण है जो बताता है कि यह कैसे किया जा सकता है।
Note- निम्नलिखित नमूना पहले से निर्मित डेटा स्रोत मान सकते हैं। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
यह नमूना ग्रहण आईडीई, एक एडब्ल्यूएस क्रेडेंशियल फ़ाइल और एडब्ल्यूएस टूलकिट को एक्लिप्स एईए जावा प्रोजेक्ट के भीतर भी उपयोग करता है।
package com.amazonaws.codesamples.document;
import java.io.IOException;
import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DeleteItemOutcome;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.UpdateItemOutcome;
import com.amazonaws.services.dynamodbv2.document.spec.DeleteItemSpec;
import com.amazonaws.services.dynamodbv2.document.spec.UpdateItemSpec;
import com.amazonaws.services.dynamodbv2.document.utils.NameMap;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
import com.amazonaws.services.dynamodbv2.model.ReturnValue;
public class UpdateItemOpSample {
static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
static String tblName = "ProductList";
public static void main(String[] args) throws IOException {
createItems();
retrieveItem();
// Execute updates
updateMultipleAttributes();
updateAddNewAttribute();
updateExistingAttributeConditionally();
// Item deletion
deleteItem();
}
private static void createItems() {
Table table = dynamoDB.getTable(tblName);
try {
Item item = new Item()
.withPrimaryKey("ID", 303)
.withString("Nomenclature", "Polymer Blaster 4000")
.withStringSet( "Manufacturers",
new HashSet<String>(Arrays.asList("XYZ Inc.", "LMNOP Inc.")))
.withNumber("Price", 50000)
.withBoolean("InProduction", true)
.withString("Category", "Laser Cutter");
table.putItem(item);
item = new Item()
.withPrimaryKey("ID", 313)
.withString("Nomenclature", "Agitatatron 2000")
.withStringSet( "Manufacturers",
new HashSet<String>(Arrays.asList("XYZ Inc,", "CDE Inc.")))
.withNumber("Price", 40000)
.withBoolean("InProduction", true)
.withString("Category", "Agitator");
table.putItem(item);
} catch (Exception e) {
System.err.println("Cannot create items.");
System.err.println(e.getMessage());
}
}
private static void updateAddNewAttribute() {
Table table = dynamoDB.getTable(tableName);
try {
Map<String, String> expressionAttributeNames = new HashMap<String, String>();
expressionAttributeNames.put("#na", "NewAttribute");
UpdateItemSpec updateItemSpec = new UpdateItemSpec()
.withPrimaryKey("ID", 303)
.withUpdateExpression("set #na = :val1")
.withNameMap(new NameMap()
.with("#na", "NewAttribute"))
.withValueMap(new ValueMap()
.withString(":val1", "A value"))
.withReturnValues(ReturnValue.ALL_NEW);
UpdateItemOutcome outcome = table.updateItem(updateItemSpec);
// Confirm
System.out.println("Displaying updated item...");
System.out.println(outcome.getItem().toJSONPretty());
} catch (Exception e) {
System.err.println("Cannot add an attribute in " + tableName);
System.err.println(e.getMessage());
}
}
}
डायनमोबी में एक आइटम को हटाने के लिए केवल टेबल नाम और आइटम कुंजी प्रदान करने की आवश्यकता होती है। सशर्त अभिव्यक्ति का उपयोग करने के लिए भी दृढ़ता से सिफारिश की जाती है जो गलत वस्तुओं को हटाने से बचने के लिए आवश्यक होगा।
हमेशा की तरह, आप इस कार्य को करने के लिए GUI कंसोल, जावा या किसी अन्य आवश्यक उपकरण का उपयोग कर सकते हैं।
GUI कंसोल का उपयोग करके आइटम हटाएं
कंसोल पर नेविगेट करें। बाईं ओर नेविगेशन फलक में, का चयन करेंTables। फिर तालिका नाम का चयन करें, औरItems टैब।
हटाने के लिए वांछित आइटम चुनें, और चुनें Actions | Delete।
ए Delete Item(s)डायलॉग बॉक्स तब दिखाई देता है जैसा कि निम्नलिखित स्क्रू में दिखाया गया है। पुष्टि करने के लिए "हटाएं" चुनें।
जावा का उपयोग करके आइटम कैसे हटाएं?
आइटम हटाने के कार्यों में जावा का उपयोग करने से केवल डायनमोबी क्लाइंट उदाहरण बनाना और कॉल करना शामिल है deleteItem आइटम की कुंजी का उपयोग करके विधि।
आप निम्नलिखित उदाहरण देख सकते हैं, जहां इसे विस्तार से समझाया गया है।
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("ProductList");
DeleteItemOutcome outcome = table.deleteItem("IDnum", 151);
आप गलत विलोपन से बचाने के लिए पैरामीटर भी निर्दिष्ट कर सकते हैं। बस एक का उपयोग करेंConditionExpression।
उदाहरण के लिए -
Map<String,Object> expressionAttributeValues = new HashMap<String,Object>();
expressionAttributeValues.put(":val", false);
DeleteItemOutcome outcome = table.deleteItem("IDnum",151,
"Ship = :val",
null, // doesn't use ExpressionAttributeNames
expressionAttributeValues);
निम्नलिखित बेहतर समझ के लिए एक बड़ा उदाहरण है।
Note- निम्नलिखित नमूना पहले से निर्मित डेटा स्रोत मान सकते हैं। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
यह नमूना ग्रहण आईडीई, एक एडब्ल्यूएस क्रेडेंशियल फ़ाइल और एडब्ल्यूएस टूलकिट को एक्लिप्स एईए जावा प्रोजेक्ट के भीतर भी उपयोग करता है।
package com.amazonaws.codesamples.document;
import java.io.IOException;
import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DeleteItemOutcome;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.UpdateItemOutcome;
import com.amazonaws.services.dynamodbv2.document.spec.DeleteItemSpec;
import com.amazonaws.services.dynamodbv2.document.spec.UpdateItemSpec;
import com.amazonaws.services.dynamodbv2.document.utils.NameMap;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
import com.amazonaws.services.dynamodbv2.model.ReturnValue;
public class DeleteItemOpSample {
static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
static String tblName = "ProductList";
public static void main(String[] args) throws IOException {
createItems();
retrieveItem();
// Execute updates
updateMultipleAttributes();
updateAddNewAttribute();
updateExistingAttributeConditionally();
// Item deletion
deleteItem();
}
private static void createItems() {
Table table = dynamoDB.getTable(tblName);
try {
Item item = new Item()
.withPrimaryKey("ID", 303)
.withString("Nomenclature", "Polymer Blaster 4000")
.withStringSet( "Manufacturers",
new HashSet<String>(Arrays.asList("XYZ Inc.", "LMNOP Inc.")))
.withNumber("Price", 50000)
.withBoolean("InProduction", true)
.withString("Category", "Laser Cutter");
table.putItem(item);
item = new Item()
.withPrimaryKey("ID", 313)
.withString("Nomenclature", "Agitatatron 2000")
.withStringSet( "Manufacturers",
new HashSet<String>(Arrays.asList("XYZ Inc,", "CDE Inc.")))
.withNumber("Price", 40000)
.withBoolean("InProduction", true)
.withString("Category", "Agitator");
table.putItem(item);
} catch (Exception e) {
System.err.println("Cannot create items.");
System.err.println(e.getMessage());
}
}
private static void deleteItem() {
Table table = dynamoDB.getTable(tableName);
try {
DeleteItemSpec deleteItemSpec = new DeleteItemSpec()
.withPrimaryKey("ID", 303)
.withConditionExpression("#ip = :val")
.withNameMap(new NameMap()
.with("#ip", "InProduction"))
.withValueMap(new ValueMap()
.withBoolean(":val", false))
.withReturnValues(ReturnValue.ALL_OLD);
DeleteItemOutcome outcome = table.deleteItem(deleteItemSpec);
// Confirm
System.out.println("Displaying deleted item...");
System.out.println(outcome.getItem().toJSONPretty());
} catch (Exception e) {
System.err.println("Cannot delete item in " + tableName);
System.err.println(e.getMessage());
}
}
}
बैच लेखन कई वस्तुओं को बनाने या हटाने के द्वारा कई मदों पर काम करता है। ये ऑपरेशन उपयोग करते हैंBatchWriteItem, जो 16MB से अधिक नहीं लिखता है और 25 अनुरोधों की सीमाओं को वहन करता है। प्रत्येक आइटम एक 400KB आकार सीमा का पालन करता है। बैच लिखते हैं भी आइटम अद्यतन नहीं कर सकता।
बैच लेखन क्या है?
बैच लिखता है कई तालिकाओं में आइटम हेरफेर कर सकते हैं। ऑपरेशन का आह्वान प्रत्येक व्यक्तिगत अनुरोध के लिए होता है, जिसका अर्थ है कि संचालन एक-दूसरे को प्रभावित नहीं करते हैं, और विषम मिश्रणों की अनुमति है; उदाहरण के लिए, एकPutItem और तीन DeleteItemएक बैच में अनुरोध, PutItem अनुरोध की विफलता के साथ दूसरों को प्रभावित नहीं करता है। प्रत्येक असफल अनुरोध से संबंधित जानकारी (चाबियाँ और डेटा) वापस करने के लिए विफल अनुरोधों के परिणामस्वरूप ऑपरेशन हुआ।
Note- अगर डायनामोडीबी किसी भी आइटम को संसाधित किए बिना लौटाता है, तो उन्हें वापस लें; हालांकि, ओवरलोडिंग के आधार पर एक अन्य अनुरोध विफलता से बचने के लिए बैक-ऑफ पद्धति का उपयोग करें।
नीचे दिए गए कथनों में से एक या अधिक सही होने पर डायनमोबीडी बैच लिखने के ऑपरेशन को खारिज कर देता है -
अनुरोध प्रावधानित विवाद से अधिक है।
अनुरोध का उपयोग करने का प्रयास करता है BatchWriteItems किसी आइटम को अद्यतन करने के लिए।
अनुरोध एक आइटम पर कई ऑपरेशन करता है।
अनुरोध तालिकाएँ मौजूद नहीं हैं।
अनुरोध में आइटम विशेषताएँ लक्ष्य से मेल नहीं खाती हैं।
अनुरोध आकार सीमा से अधिक हैं।
बैच लिखते हैं कुछ की आवश्यकता है RequestItem पैरामीटर -
विचलन संचालन की आवश्यकता है DeleteRequest चाभी subelements एक विशेषता नाम और मूल्य का अर्थ है।
PutRequest आइटम की आवश्यकता है Item subelement एक विशेषता और विशेषता मान मानचित्र का अर्थ है।
Response - HTTP 200 की प्रतिक्रिया में एक सफल ऑपरेशन का परिणाम होता है, जो कि खपत की जाने वाली क्षमता इकाइयों, टेबल प्रोसेसिंग मेट्रिक्स और किसी भी असंसाधित वस्तुओं जैसी विशेषताओं को इंगित करता है।
जावा के साथ बैच लिखते हैं
डायनामो बी बी श्रेणी उदाहरण बनाकर एक बैच लेखन करें TableWriteItems सभी ऑपरेशनों का वर्णन करने वाला वर्ग उदाहरण, और कॉल करना batchWriteItem TableWriteItems ऑब्जेक्ट का उपयोग करने की विधि।
Note- आपको एक तालिका में कई तालिका लिखने के लिए प्रत्येक तालिका के लिए TableWriteItems उदाहरण बनाना होगा। इसके अलावा, किसी भी अप्रमाणित अनुरोध के लिए अपने अनुरोध की प्रतिक्रिया देखें।
आप एक बैच लिखने के निम्नलिखित उदाहरण की समीक्षा कर सकते हैं -
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
TableWriteItems forumTableWriteItems = new TableWriteItems("Forum")
.withItemsToPut(
new Item()
.withPrimaryKey("Title", "XYZ CRM")
.withNumber("Threads", 0));
TableWriteItems threadTableWriteItems = new TableWriteItems(Thread)
.withItemsToPut(
new Item()
.withPrimaryKey("ForumTitle","XYZ CRM","Topic","Updates")
.withHashAndRangeKeysToDelete("ForumTitle","A partition key value",
"Product Line 1", "A sort key value"));
BatchWriteItemOutcome outcome = dynamoDB.batchWriteItem (
forumTableWriteItems, threadTableWriteItems);
जावा के साथ एक बैच कैसे लिखता है, इसकी बेहतर समझ के लिए निम्नलिखित कार्यक्रम एक और बड़ा उदाहरण है।
Note- निम्नलिखित उदाहरण पहले से बनाए गए डेटा स्रोत को मान सकते हैं। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
यह उदाहरण ग्रहण आईडीई, AWS क्रेडेंशियल फ़ाइल और AWS टूलकिट का उपयोग ग्रहण Ase Java प्रोजेक्ट के भीतर भी करता है।
package com.amazonaws.codesamples.document;
import java.io.IOException;
import java.util.Arrays;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.BatchWriteItemOutcome;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.TableWriteItems;
import com.amazonaws.services.dynamodbv2.model.WriteRequest;
public class BatchWriteOpSample {
static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
static String forumTableName = "Forum";
static String threadTableName = "Thread";
public static void main(String[] args) throws IOException {
batchWriteMultiItems();
}
private static void batchWriteMultiItems() {
try {
// Place new item in Forum
TableWriteItems forumTableWriteItems = new TableWriteItems(forumTableName)
//Forum
.withItemsToPut(new Item()
.withPrimaryKey("Name", "Amazon RDS")
.withNumber("Threads", 0));
// Place one item, delete another in Thread
// Specify partition key and range key
TableWriteItems threadTableWriteItems = new TableWriteItems(threadTableName)
.withItemsToPut(new Item()
.withPrimaryKey("ForumName","Product
Support","Subject","Support Thread 1")
.withString("Message", "New OS Thread 1 message")
.withHashAndRangeKeysToDelete("ForumName","Subject", "Polymer Blaster",
"Support Thread 100"));
System.out.println("Processing request...");
BatchWriteItemOutcome outcome = dynamoDB.batchWriteItem (
forumTableWriteItems, threadTableWriteItems);
do {
// Confirm no unprocessed items
Map<String, List<WriteRequest>> unprocessedItems
= outcome.getUnprocessedItems();
if (outcome.getUnprocessedItems().size() == 0) {
System.out.println("All items processed.");
} else {
System.out.println("Gathering unprocessed items...");
outcome = dynamoDB.batchWriteItemUnprocessed(unprocessedItems);
}
} while (outcome.getUnprocessedItems().size() > 0);
} catch (Exception e) {
System.err.println("Could not get items: ");
e.printStackTrace(System.err);
}
}
}
बैच एक या एक से अधिक आइटमों के प्रचालनों को वापस लौटाता है। ये ऑपरेशन आम तौर पर वांछित वस्तु (ओं) की पहचान करने के लिए प्राथमिक कुंजी का उपयोग करते हैं। BatchGetItem संचालन व्यक्तिगत संचालन की सीमाओं के साथ-साथ अपने स्वयं के अनूठे अवरोधों के अधीन हैं।
बैच पुनः प्राप्ति संचालन में निम्नलिखित अनुरोधों के परिणामस्वरूप अस्वीकृति -
- 100 से अधिक वस्तुओं के लिए अनुरोध करें।
- अनुरोध थ्रूपुट से अधिक करें।
बैच पुनः प्राप्त करने का कार्य सीमाओं को पार करने की क्षमता को लेकर अनुरोधों का आंशिक प्रसंस्करण करता है।
For example- अनुरोध प्रसंस्करण के हिस्से में परिणाम को सीमित करने के लिए आकार में कई वस्तुओं को पर्याप्त रूप से पुनर्प्राप्त करने के लिए एक अनुरोध, और एक त्रुटि संदेश अप्रमाणित भाग को नोट कर रहा है। असंसाधित वस्तुओं की वापसी पर, थ्रॉटलिंग टेबल के बजाय इसे प्रबंधित करने के लिए बैक-ऑफ एल्गोरिथ्म समाधान बनाएं।
BatchGetसंचालन आखिरकार लगातार पठन के साथ प्रदर्शन करते हैं, जिसमें दृढ़ता से संगत लोगों के लिए संशोधन की आवश्यकता होती है। वे समानांतर रूप से पुनर्प्राप्ति भी करते हैं।
Note- लौटी वस्तुओं का क्रम। DynamoDB आइटम सॉर्ट नहीं करता है। यह अनुरोधित वस्तुओं की अनुपस्थिति को भी नहीं दर्शाता है। इसके अलावा, वे अनुरोध क्षमता इकाइयों का उपभोग करते हैं।
सभी बैच ऑपरेशन की आवश्यकता है RequestItems रीड कंसिस्टेंसी, विशेषता नाम और प्राथमिक कुंजी जैसे पैरामीटर।
Response - HTTP 200 की प्रतिक्रिया में एक सफल ऑपरेशन का परिणाम होता है, जो कि खपत की जाने वाली क्षमता इकाइयों, टेबल प्रोसेसिंग मेट्रिक्स और किसी भी असंसाधित वस्तुओं जैसी विशेषताओं को इंगित करता है।
जावा के साथ बैच पुनर्प्राप्ति
BatchGet परिचालनों में Java का उपयोग करने के लिए एक DynamoDB वर्ग उदाहरण बनाने की आवश्यकता होती है, TableKeysAndAttributes आइटम के लिए एक प्राथमिक प्रमुख मान सूची का वर्णन करने वाला वर्ग उदाहरण, और TableKeysAndAttributes ऑब्जेक्ट को पास करना BatchGetItem तरीका।
निम्नलिखित बैच ऑपरेशन का एक उदाहरण है -
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient (
new ProfileCredentialsProvider()));
TableKeysAndAttributes forumTableKeysAndAttributes = new TableKeysAndAttributes
(forumTableName);
forumTableKeysAndAttributes.addHashOnlyPrimaryKeys (
"Title",
"Updates",
"Product Line 1"
);
TableKeysAndAttributes threadTableKeysAndAttributes = new TableKeysAndAttributes (
threadTableName);
threadTableKeysAndAttributes.addHashAndRangePrimaryKeys (
"ForumTitle",
"Topic",
"Product Line 1",
"P1 Thread 1",
"Product Line 1",
"P1 Thread 2",
"Product Line 2",
"P2 Thread 1"
);
BatchGetItemOutcome outcome = dynamoDB.batchGetItem (
forumTableKeysAndAttributes, threadTableKeysAndAttributes);
for (String tableName : outcome.getTableItems().keySet()) {
System.out.println("Table items " + tableName);
List<Item> items = outcome.getTableItems().get(tableName);
for (Item item : items) {
System.out.println(item);
}
}
आप निम्नलिखित बड़े उदाहरण की समीक्षा कर सकते हैं।
Note- निम्न प्रोग्राम पहले से बनाए गए डेटा स्रोत को मान सकता है। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
यह प्रोग्राम ग्रहण आईडीई, एक एडब्ल्यूएस क्रेडेंशियल फ़ाइल और एडब्ल्यूएस टूलकिट को एक्लिप्स एईए जावा प्रोजेक्ट के भीतर भी उपयोग करता है।
package com.amazonaws.codesamples.document;
import java.io.IOException;
import java.util.List;
import java.util.Map;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.BatchGetItemOutcome;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.TableKeysAndAttributes;
import com.amazonaws.services.dynamodbv2.model.KeysAndAttributes;
public class BatchGetOpSample {
static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient (
new ProfileCredentialsProvider()));
static String forumTableName = "Forum";
static String threadTableName = "Thread";
public static void main(String[] args) throws IOException {
retrieveMultipleItemsBatchGet();
}
private static void retrieveMultipleItemsBatchGet() {
try {
TableKeysAndAttributes forumTableKeysAndAttributes =
new TableKeysAndAttributes(forumTableName);
//Create partition key
forumTableKeysAndAttributes.addHashOnlyPrimaryKeys (
"Name",
"XYZ Melt-O-tron",
"High-Performance Processing"
);
TableKeysAndAttributes threadTableKeysAndAttributes =
new TableKeysAndAttributes(threadTableName);
//Create partition key and sort key
threadTableKeysAndAttributes.addHashAndRangePrimaryKeys (
"ForumName",
"Subject",
"High-Performance Processing",
"HP Processing Thread One",
"High-Performance Processing",
"HP Processing Thread Two",
"Melt-O-Tron",
"MeltO Thread One"
);
System.out.println("Processing...");
BatchGetItemOutcome outcome = dynamoDB.batchGetItem(forumTableKeysAndAttributes,
threadTableKeysAndAttributes);
Map<String, KeysAndAttributes> unprocessed = null;
do {
for (String tableName : outcome.getTableItems().keySet()) {
System.out.println("Table items for " + tableName);
List<Item> items = outcome.getTableItems().get(tableName);
for (Item item : items) {
System.out.println(item.toJSONPretty());
}
}
// Confirm no unprocessed items
unprocessed = outcome.getUnprocessedKeys();
if (unprocessed.isEmpty()) {
System.out.println("All items processed.");
} else {
System.out.println("Gathering unprocessed items...");
outcome = dynamoDB.batchGetItemUnprocessed(unprocessed);
}
} while (!unprocessed.isEmpty());
} catch (Exception e) {
System.err.println("Could not get items.");
System.err.println(e.getMessage());
}
}
}
क्वेरी प्राथमिक कुंजी के माध्यम से आइटम या द्वितीयक सूचकांक का पता लगाती हैं। एक क्वेरी करने के लिए एक विभाजन कुंजी और विशिष्ट मूल्य, या एक सॉर्ट कुंजी और मूल्य की आवश्यकता होती है; तुलना के साथ फ़िल्टर करने के विकल्प के साथ। किसी क्वेरी के डिफ़ॉल्ट व्यवहार में दिए गए प्राथमिक कुंजी के साथ जुड़ी वस्तुओं के लिए हर विशेषता को वापस करना शामिल है। हालाँकि, आप इच्छित विशेषताओं को निर्दिष्ट कर सकते हैंProjectionExpression पैरामीटर।
एक क्वेरी का उपयोग करता है KeyConditionExpressionआइटम का चयन करने के लिए पैरामीटर, जिसमें एक समानता की स्थिति के रूप में विभाजन कुंजी नाम और मूल्य प्रदान करने की आवश्यकता होती है। आपके पास मौजूद किसी भी प्रकार की कुंजी के लिए एक अतिरिक्त शर्त प्रदान करने का विकल्प है।
सॉर्ट की प्रमुख स्थितियों के कुछ उदाहरण हैं -
अनु क्रमांक | स्थिति का वर्णन |
---|---|
1 | x = y यदि गुण x बराबर y है तो यह सत्य का मूल्यांकन करता है। |
2 | x < y यदि x से y कम है तो यह सत्य का मूल्यांकन करता है। |
3 | x <= y यदि x से y के बराबर या उससे कम है तो यह सत्य का मूल्यांकन करता है। |
4 | x > y यदि x से y अधिक है तो यह सत्य का मूल्यांकन करता है। |
5 | x >= y यदि x से y के बराबर या अधिक है तो यह सत्य का मूल्यांकन करता है। |
6 | x BETWEEN y AND z यदि x => y, और <= z दोनों है तो यह सत्य का मूल्यांकन करता है। |
DynamoDB भी निम्नलिखित कार्यों का समर्थन करता है: begins_with (x, substr)
यह निर्दिष्ट एक्स के साथ विशेषता एक्स शुरू होता है, तो यह सच है।
निम्नलिखित शर्तों को कुछ आवश्यकताओं के अनुरूप होना चाहिए -
गुण नाम az या AZ सेट के भीतर एक चरित्र से शुरू होना चाहिए।
विशेषता नाम का दूसरा वर्ण az, AZ या 0-9 सेट में आना चाहिए।
गुण नाम आरक्षित शब्दों का उपयोग नहीं कर सकते।
ऊपर दिए गए अवरोधों के अनुपालन से बाहर के नामों को जोड़ना एक प्लेसहोल्डर को परिभाषित कर सकता है।
सॉर्ट कुंजी क्रम में पुनर्प्राप्ति का प्रदर्शन करके और वर्तमान में मौजूद किसी भी स्थिति और फ़िल्टर अभिव्यक्ति का उपयोग करके क्वेरी की प्रक्रिया। प्रश्न हमेशा एक परिणाम सेट लौटाते हैं, और कोई मिलान नहीं होने पर, यह एक खाली रिटर्न देता है।
परिणाम हमेशा क्रमबद्ध कुंजी क्रम में लौटते हैं, और आरोही क्रम के रूप में परिवर्तनीय डिफ़ॉल्ट के साथ डेटा प्रकार आधारित आदेश।
जावा के साथ क्वेरी करना
जावा में क्वेरी आपको टेबल और सेकेंडरी इंडेक्स को क्वेरी करने की अनुमति देती है। उन्हें सॉर्ट कुंजी और शर्तों को निर्दिष्ट करने के विकल्प के साथ विभाजन कुंजी और समानता की शर्तों के विनिर्देश की आवश्यकता होती है।
जावा में क्वेरी के लिए सामान्य आवश्यक कदमों में डायनामोडीबी श्रेणी का उदाहरण बनाना, लक्ष्य तालिका के लिए तालिका वर्ग उदाहरण और क्वेरी वस्तु प्राप्त करने के लिए तालिका उदाहरण की क्वेरी विधि को शामिल करना शामिल है।
क्वेरी की प्रतिक्रिया में ए शामिल है ItemCollection सभी लौटे आइटम प्रदान करने वाली वस्तु।
निम्न उदाहरण विस्तृत क्वेरी दर्शाता है -
DynamoDB dynamoDB = new DynamoDB (
new AmazonDynamoDBClient(new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("Response");
QuerySpec spec = new QuerySpec()
.withKeyConditionExpression("ID = :nn")
.withValueMap(new ValueMap()
.withString(":nn", "Product Line 1#P1 Thread 1"));
ItemCollection<QueryOutcome> items = table.query(spec);
Iterator<Item> iterator = items.iterator();
Item item = null;
while (iterator.hasNext()) {
item = iterator.next();
System.out.println(item.toJSONPretty());
}
क्वेरी विधि वैकल्पिक मापदंडों की एक विस्तृत विविधता का समर्थन करती है। निम्न उदाहरण दर्शाता है कि इन मापदंडों का उपयोग कैसे किया जाता है -
Table table = dynamoDB.getTable("Response");
QuerySpec spec = new QuerySpec()
.withKeyConditionExpression("ID = :nn and ResponseTM > :nn_responseTM")
.withFilterExpression("Author = :nn_author")
.withValueMap(new ValueMap()
.withString(":nn", "Product Line 1#P1 Thread 1")
.withString(":nn_responseTM", twoWeeksAgoStr)
.withString(":nn_author", "Member 123"))
.withConsistentRead(true);
ItemCollection<QueryOutcome> items = table.query(spec);
Iterator<Item> iterator = items.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next().toJSONPretty());
}
आप निम्नलिखित बड़े उदाहरण की भी समीक्षा कर सकते हैं।
Note- निम्न प्रोग्राम पहले से बनाए गए डेटा स्रोत को मान सकता है। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
यह उदाहरण ग्रहण आईडीई, AWS क्रेडेंशियल फ़ाइल और AWS टूलकिट का उपयोग ग्रहण Ase Java प्रोजेक्ट के भीतर भी करता है।
package com.amazonaws.codesamples.document;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Iterator;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.ItemCollection;
import com.amazonaws.services.dynamodbv2.document.Page;
import com.amazonaws.services.dynamodbv2.document.QueryOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.spec.QuerySpec;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
public class QueryOpSample {
static DynamoDB dynamoDB = new DynamoDB(
new AmazonDynamoDBClient(new ProfileCredentialsProvider()));
static String tableName = "Reply";
public static void main(String[] args) throws Exception {
String forumName = "PolyBlaster";
String threadSubject = "PolyBlaster Thread 1";
getThreadReplies(forumName, threadSubject);
}
private static void getThreadReplies(String forumName, String threadSubject) {
Table table = dynamoDB.getTable(tableName);
String replyId = forumName + "#" + threadSubject;
QuerySpec spec = new QuerySpec()
.withKeyConditionExpression("Id = :v_id")
.withValueMap(new ValueMap()
.withString(":v_id", replyId));
ItemCollection<QueryOutcome> items = table.query(spec);
System.out.println("\ngetThreadReplies results:");
Iterator<Item> iterator = items.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next().toJSONPretty());
}
}
}
स्कैन ऑपरेशंस सभी टेबल आइटम या सेकेंडरी इंडेक्स पढ़ते हैं। इसके डिफ़ॉल्ट फ़ंक्शन के परिणामस्वरूप किसी इंडेक्स या टेबल के भीतर सभी आइटम्स की सभी डेटा विशेषताएँ वापस आ जाती हैं। को रोजगार देंProjectionExpression फ़िल्टरिंग विशेषताओं में पैरामीटर।
कोई भी मैच नहीं मिलने पर भी हर स्कैन एक परिणाम सेट देता है, जिसके परिणामस्वरूप एक खाली सेट होता है। स्कैन डेटा को फ़िल्टर करने के विकल्प के साथ स्कैन 1 एमबी से अधिक नहीं लेते हैं।
Note - स्कैन के पैरामीटर और फ़िल्टरिंग भी क्वेरी पर लागू होते हैं।
स्कैन ऑपरेशन के प्रकार
Filtering- स्कैन ऑपरेशन फ़िल्टर एक्सप्रेशंस के माध्यम से ठीक फ़िल्टरिंग प्रदान करते हैं, जो स्कैन, या प्रश्नों के बाद डेटा को संशोधित करते हैं; परिणाम लौटने से पहले। अभिव्यक्ति तुलना ऑपरेटरों का उपयोग करते हैं। उनके सिंटैक्स प्रमुख विशेषताओं के अपवाद के साथ स्थिति के भावों से मिलते-जुलते हैं, जो फ़िल्टर अभिव्यक्तियों को अनुमति नहीं देते हैं। आप किसी फ़िल्टर एक्सप्रेशन में पार्टीशन या सॉर्ट कुंजी का उपयोग नहीं कर सकते।
Note - 1 एमबी सीमा फ़िल्टरिंग के किसी भी आवेदन से पहले लागू होती है।
Throughput Specifications- स्कैन, थ्रूपुट का उपभोग करते हैं, हालांकि, खपत लौटे डेटा के बजाय आइटम के आकार पर केंद्रित है। खपत वही रहती है चाहे आप प्रत्येक विशेषता या केवल कुछ का अनुरोध करते हैं, और फ़िल्टर अभिव्यक्ति का उपयोग करना या नहीं करना भी खपत को प्रभावित नहीं करता है।
Pagination- डायनेमोडीबी परिणामों के विशिष्ट पृष्ठों में विभाजन का कारण बनता है। 1MB सीमा लौटे परिणामों पर लागू होती है, और जब आप इसे पार करते हैं, तो बाकी डेटा इकट्ठा करने के लिए एक और स्कैन आवश्यक हो जाता है। LastEvaluatedKeyमान आपको बाद में स्कैन करने की अनुमति देता है। बस मान को लागू करेंExclusiveStartkey। जबLastEvaluatedKeyमान शून्य हो जाता है, ऑपरेशन ने डेटा के सभी पृष्ठ पूरे कर लिए हैं। हालांकि, एक गैर-शून्य मान का मतलब यह नहीं है कि अधिक डेटा शेष है। केवल एक शून्य मान स्थिति को इंगित करता है।
The Limit Parameter- सीमा पैरामीटर परिणाम आकार का प्रबंधन करता है। डायनामो डीबी डेटा वापस करने से पहले संसाधित करने के लिए वस्तुओं की संख्या को स्थापित करने के लिए इसका उपयोग करता है, और दायरे से बाहर काम नहीं करता है। यदि आप x का मान सेट करते हैं, तो DynamoDB पहला x मिलान आइटम लौटाता है।
LastEvalittedKey मान आंशिक परिणाम देने वाले सीमा मापदंडों के मामलों में भी लागू होता है। इसका उपयोग स्कैन पूरा करने के लिए करें।
Result Count - प्रश्नों और स्कैन के जवाबों से संबंधित जानकारी भी शामिल है ScannedCountऔर गणना करें, जो स्कैन की गई / queried वस्तुओं को निर्धारित करती है और लौटाई गई वस्तुओं की मात्रा निर्धारित करती है। यदि आप फ़िल्टर नहीं करते हैं, तो उनके मूल्य समान हैं। जब आप 1 एमबी से अधिक हो जाते हैं, तो गणना केवल संसाधित किए गए भाग का प्रतिनिधित्व करती है।
Consistency- क्वेरी परिणाम और स्कैन के परिणाम अंततः सुसंगत रूप से पढ़े जाते हैं, हालांकि, आप दृढ़ता से सुसंगत रूप से भी पढ़ सकते हैं। उपयोगConsistentRead इस सेटिंग को बदलने के लिए पैरामीटर।
Note - लगातार पढ़ी गई सेटिंग्स प्रभाव क्षमता का दोगुना उपयोग करके तब प्रभाव डालती हैं, जब दृढ़ता से संगत होती हैं।
Performance- पूर्ण तालिका या द्वितीयक सूचकांक क्रॉलिंग स्कैन के कारण क्वेरी स्कैन की तुलना में बेहतर प्रदर्शन प्रदान करती हैं, जिसके परिणामस्वरूप सुस्त प्रतिक्रिया और भारी थ्रूपुट की खपत होती है। स्कैन छोटी तालिकाओं के लिए सबसे अच्छा काम करता है और कम फिल्टर के साथ खोज करता है, हालांकि, आप कुछ सर्वोत्तम प्रथाओं जैसे कि अचानक से बचने, त्वरित गतिविधि पढ़ने और समानांतर स्कैन का दोहन करके दुबला स्कैन डिजाइन कर सकते हैं।
किसी क्वेरी में दी गई स्थिति को संतुष्ट करने वाली कुंजियों की एक निश्चित श्रृंखला मिलती है, प्रदर्शन के साथ-साथ यह डेटा की मात्रा द्वारा निर्धारित होता है जो कुंजी की मात्रा के बजाय पुनर्प्राप्त करता है। ऑपरेशन के मापदंडों और मैचों की संख्या विशेष रूप से प्रदर्शन को प्रभावित करती है।
समानांतर स्कैन
स्कैन ऑपरेशन डिफ़ॉल्ट रूप से क्रमिक रूप से प्रसंस्करण करते हैं। फिर वे 1MB भागों में डेटा लौटाते हैं, जो अगले हिस्से को लाने के लिए एप्लिकेशन को संकेत देता है। इसके परिणामस्वरूप बड़ी तालिकाओं और सूचकांकों के लिए लंबे स्कैन होते हैं।
इस विशेषता का यह भी मतलब है कि स्कैन हमेशा उपलब्ध थ्रूपुट का पूरी तरह से शोषण नहीं कर सकता है। डायनेमोबीडी कई विभाजनों में तालिका डेटा वितरित करता है; और स्कैन थ्रूपुट अपने एकल-विभाजन ऑपरेशन के कारण एकल विभाजन तक सीमित रहता है।
इस समस्या का एक समाधान तार्किक रूप से टेबल या इंडेक्स को खंडों में विभाजित करने से आता है। तब "कार्यकर्ता" समानांतर (समवर्ती) स्कैन खंडों। यह सेगमेंट के मापदंडों और का उपयोग करता हैTotalSegments कुछ श्रमिकों द्वारा स्कैन किए गए सेगमेंट को निर्दिष्ट करने और संसाधित किए गए सेगमेंट की कुल मात्रा निर्दिष्ट करने के लिए।
कार्यकर्ता संख्या
सबसे अच्छा अनुप्रयोग प्रदर्शन प्राप्त करने के लिए आपको कार्यकर्ता मानों (सेगमेंट पैरामीटर) के साथ प्रयोग करना चाहिए।
Note- श्रमिकों के बड़े सेट के साथ समानांतर स्कैन संभवतः सभी थ्रूपुट का उपभोग करके थ्रूपुट को प्रभावित करता है। इस समस्या को सीमा पैरामीटर के साथ प्रबंधित करें, जिसका उपयोग आप किसी भी कार्यकर्ता को सभी थ्रूपुट के उपभोग से रोकने के लिए कर सकते हैं।
निम्नलिखित एक गहरी स्कैन उदाहरण है।
Note- निम्न प्रोग्राम पहले से बनाए गए डेटा स्रोत को मान सकता है। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
यह उदाहरण ग्रहण आईडीई, AWS क्रेडेंशियल फ़ाइल और AWS टूलकिट का उपयोग ग्रहण Ase Java प्रोजेक्ट के भीतर भी करता है।
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.ItemCollection;
import com.amazonaws.services.dynamodbv2.document.ScanOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;
public class ScanOpSample {
static DynamoDB dynamoDB = new DynamoDB(
new AmazonDynamoDBClient(new ProfileCredentialsProvider()));
static String tableName = "ProductList";
public static void main(String[] args) throws Exception {
findProductsUnderOneHun(); //finds products under 100 dollars
}
private static void findProductsUnderOneHun() {
Table table = dynamoDB.getTable(tableName);
Map<String, Object> expressionAttributeValues = new HashMap<String, Object>();
expressionAttributeValues.put(":pr", 100);
ItemCollection<ScanOutcome> items = table.scan (
"Price < :pr", //FilterExpression
"ID, Nomenclature, ProductCategory, Price", //ProjectionExpression
null, //No ExpressionAttributeNames
expressionAttributeValues);
System.out.println("Scanned " + tableName + " to find items under $100.");
Iterator<Item> iterator = items.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next().toJSONPretty());
}
}
}
DynamoDB प्राथमिक कुंजी विशेषताओं तक पहुंच में सुधार करने के लिए अनुक्रमित का उपयोग करता है। वे एप्लिकेशन एक्सेस और डेटा पुनर्प्राप्ति में तेजी लाते हैं, और एप्लिकेशन लैग को कम करके बेहतर प्रदर्शन का समर्थन करते हैं।
द्वितीयक सूचकांक
एक द्वितीयक सूचकांक एक विशेषता सबसेट और एक वैकल्पिक कुंजी रखता है। आप इसे क्वेरी या स्कैन ऑपरेशन के माध्यम से उपयोग करते हैं, जो सूचकांक को लक्षित करता है।
इसकी सामग्री में आपके द्वारा प्रोजेक्ट या कॉपी की गई विशेषताएँ शामिल हैं। निर्माण में, आप सूचकांक के लिए एक वैकल्पिक कुंजी निर्धारित करते हैं, और कोई भी विशेषता जिसे आप सूचकांक में प्रोजेक्ट करना चाहते हैं। डायनामो डीबी तब सूचकांक में विशेषताओं की एक प्रति प्रदर्शित करता है, जिसमें मेज से प्राथमिक प्राथमिक गुण शामिल होते हैं। इन कार्यों को करने के बाद, आप बस एक क्वेरी / स्कैन का उपयोग करते हैं जैसे कि एक टेबल पर प्रदर्शन करना।
DynamoDB स्वचालित रूप से सभी माध्यमिक सूचकांकों को बनाए रखता है। आइटम संचालन पर, जैसे जोड़ना या हटाना, यह लक्ष्य तालिका पर किसी भी अनुक्रमणिका को अद्यतन करता है।
डायनेमोबीडी दो प्रकार के द्वितीयक सूचकांक प्रदान करता है -
Global Secondary Index- इस सूचकांक में एक विभाजन कुंजी और सॉर्ट कुंजी शामिल है, जो स्रोत तालिका से भिन्न हो सकती है। यह सभी टेबल डेटा और सभी विभाजनों को अनुक्रमित करने के लिए सूचकांक पर प्रश्नों / स्कैन की क्षमता के कारण "वैश्विक" लेबल का उपयोग करता है।
Local Secondary Index- यह सूचकांक तालिका के साथ एक विभाजन कुंजी साझा करता है, लेकिन एक अलग तरह की कुंजी का उपयोग करता है। इसकी "स्थानीय" प्रकृति समान विभाजन कुंजी मान के साथ तालिका विभाजन के लिए अपने सभी विभाजनों के परिणामस्वरूप होती है।
सूचकांक का उपयोग करने का सबसे अच्छा प्रकार आवेदन की जरूरतों पर निर्भर करता है। निम्नलिखित तालिका में प्रस्तुत दोनों के बीच अंतर पर विचार करें -
गुणवत्ता | वैश्विक माध्यमिक सूचकांक | स्थानीय माध्यमिक सूचकांक |
---|---|---|
प्रमुख योजनाएँ | यह एक साधारण या समग्र प्राथमिक कुंजी का उपयोग करता है। | यह हमेशा एक संयुक्त प्राथमिक कुंजी का उपयोग करता है। |
मुख्य विशेषताएं | सूचकांक विभाजन कुंजी और सॉर्ट कुंजी में स्ट्रिंग, संख्या या बाइनरी टेबल विशेषताएँ शामिल हो सकती हैं। | सूचकांक की विभाजन कुंजी एक विशेषता है जो तालिका विभाजन कुंजी के साथ साझा की जाती है। सॉर्ट कुंजी स्ट्रिंग, संख्या या बाइनरी टेबल विशेषताएँ हो सकती है। |
आकार प्रति विभाजन कुंजी मूल्य | वे कोई आकार सीमा नहीं रखते हैं। | यह एक विभाजन कुंजी मूल्य से जुड़े अनुक्रमित वस्तुओं के कुल आकार पर 10GB अधिकतम सीमा लगाता है। |
ऑनलाइन सूचकांक संचालन | आप उन्हें टेबल निर्माण में स्पॉन कर सकते हैं, उन्हें मौजूदा तालिकाओं में जोड़ सकते हैं या मौजूदा वाले हटा सकते हैं। | आपको उन्हें तालिका निर्माण में बनाना होगा, लेकिन उन्हें हटा नहीं सकते या उन्हें मौजूदा तालिकाओं में नहीं जोड़ सकते। |
प्रश्नों | यह संपूर्ण तालिका और प्रत्येक विभाजन को कवर करने वाले प्रश्नों की अनुमति देता है। | वे क्वेरी में दिए गए विभाजन कुंजी मान के माध्यम से एकल विभाजन को संबोधित करते हैं। |
संगति | इन सूचकांकों की क्वेरी केवल अंततः सुसंगत विकल्प प्रदान करती हैं। | इनमें से प्रश्न अंतत: सुसंगत या दृढ़ता से सुसंगत के विकल्प प्रदान करते हैं। |
थ्रूपुट लागत | इसमें रीड एंड राइट के लिए थ्रूपुट सेटिंग्स शामिल हैं। इंडेक्स से क्वेरीज़ / स्कैन क्षमता का उपभोग करते हैं, न कि टेबल, जो टेबल राइट अपडेट पर भी लागू होती है। | क्वेरीज़ / स्कैन टेबल रीड क्षमता का उपभोग करते हैं। तालिका स्थानीय अनुक्रमणिकाओं को अद्यतन करती है, और तालिका क्षमता इकाइयों का उपभोग करती है। |
प्रक्षेपण | सूचकांक / स्कैन केवल तालिका विशेषताओं की कोई पुनर्प्राप्ति के साथ, सूचकांक में अनुमानित विशेषताओं का अनुरोध कर सकते हैं। | क्वेरी / स्कैन उन विशेषताओं का अनुरोध कर सकते हैं जो अनुमानित नहीं हैं; इसके अलावा, उनमें से स्वचालित भ्रूण होते हैं। |
माध्यमिक अनुक्रमित के साथ कई तालिकाओं का निर्माण करते समय, इसे क्रमिक रूप से करें; अर्थ एक टेबल बनाते हैं और दूसरी और फिर से प्रतीक्षा करने से पहले इसे सक्रिय स्थिति तक पहुंचने के लिए इंतजार करते हैं। डायनॉम्बीडी समवर्ती निर्माण की अनुमति नहीं देता है।
प्रत्येक माध्यमिक सूचकांक को कुछ विशिष्टताओं की आवश्यकता होती है -
Type - स्थानीय या वैश्विक निर्दिष्ट करें।
Name - यह तालिकाओं के समान नामकरण नियमों का उपयोग करता है।
Key Schema - इंडेक्स प्रकार अन्य आवश्यकताओं को निर्धारित करने के साथ केवल शीर्ष स्तर स्ट्रिंग, संख्या, या बाइनरी प्रकार की अनुमति है।
Attributes for Projection - डायनॉम्बीडी स्वचालित रूप से उन्हें प्रोजेक्ट करता है, और किसी भी डेटा प्रकार की अनुमति देता है।
Throughput - वैश्विक माध्यमिक अनुक्रमित के लिए पढ़ने / लिखने की क्षमता निर्दिष्ट करें।
इंडेक्स की सीमा 5 वैश्विक और 5 स्थानीय प्रति तालिका बनी हुई है।
आप अनुक्रमणिका के बारे में विस्तृत जानकारी के साथ पहुँच सकते हैं DescribeTable। यह नाम, आकार और आइटम गणना देता है।
Note - ये मान हर 6 घंटे में अपडेट होते हैं।
सूचकांक डेटा तक पहुंचने के लिए उपयोग किए जाने वाले प्रश्नों या स्कैन में, तालिका और सूचकांक के नाम, परिणाम के लिए वांछित विशेषताएँ और कोई भी सशर्त विवरण प्रदान करें। DynamoDB, आरोही या अवरोही क्रम में परिणाम वापस करने का विकल्प प्रदान करता है।
Note - एक टेबल को हटाने से सभी इंडेक्स भी डिलीट हो जाते हैं।
विभिन्न विशेषताओं के साथ विभिन्न क्वेरी प्रकारों की आवश्यकता वाले अनुप्रयोग इन विस्तृत प्रश्नों को करने में एकल या एकाधिक वैश्विक माध्यमिक अनुक्रमित का उपयोग कर सकते हैं।
For example - उपयोगकर्ताओं का एक ट्रैक रखने वाली प्रणाली, उनकी लॉगिन स्थिति और उनका समय लॉग इन होता है। पिछले उदाहरण की वृद्धि इसके डेटा पर प्रश्नों को धीमा कर देती है।
वैश्विक माध्यमिक सूचकांक एक तालिका से विशेषताओं के चयन का आयोजन करके प्रश्नों को तेज करते हैं। वे डेटा को सॉर्ट करने में प्राथमिक कुंजी नियोजित करते हैं, और तालिका के समान कोई कुंजी तालिका विशेषताएँ, या कुंजी स्कीमा की आवश्यकता नहीं होती है।
सभी वैश्विक सेकेंडरी इंडेक्स में एक सॉर्ट कुंजी के विकल्प के साथ एक विभाजन कुंजी शामिल होनी चाहिए। अनुक्रमणिका कुंजी स्कीमा तालिका से भिन्न हो सकती है, और अनुक्रमणिका कुंजी विशेषताएँ किसी भी शीर्ष-स्तरीय स्ट्रिंग, संख्या, या बाइनरी तालिका विशेषताओं का उपयोग कर सकती हैं।
एक प्रक्षेपण में, आप अन्य तालिका विशेषताओं का उपयोग कर सकते हैं, हालांकि, प्रश्न माता-पिता की तालिकाओं से पुनर्प्राप्त नहीं होते हैं।
गुण का अनुमान
अनुमानों में तालिका से द्वितीयक सूचकांक में कॉपी किए गए विशेषता सेट होते हैं। हमेशा तालिका विभाजन कुंजी और सॉर्ट कुंजी के साथ एक प्रोजेक्शन होता है। प्रश्नों में, अनुमान प्रक्षेपण की किसी भी विशेषता के लिए डायनेमोडी एक्सेस की अनुमति देते हैं; वे अनिवार्य रूप से अपनी तालिका के रूप में मौजूद हैं।
एक माध्यमिक सूचकांक निर्माण में, आपको प्रक्षेपण के लिए विशेषताओं को निर्दिष्ट करना होगा। DynamoDB इस कार्य को करने के लिए तीन तरीके प्रदान करता है -
KEYS_ONLY- सभी सूचकांक आइटम तालिका विभाजन से मिलकर बने होते हैं और प्रमुख मानों को छांटते हैं, और प्रमुख कुंजी मूल्य। यह सबसे छोटा सूचकांक बनाता है।
INCLUDE - इसमें KEYS_ONLY विशेषताएँ और निर्दिष्ट गैर-प्रमुख विशेषताएँ शामिल हैं।
ALL - इसमें सभी स्रोत तालिका विशेषताएँ शामिल हैं, जो सबसे बड़ा संभव सूचकांक बनाता है।
एक ग्लोबल सेकेंडरी इंडेक्स में प्रोजेक्टिंग विशेषताओं में ट्रेडऑफ पर ध्यान दें, जो थ्रूपुट और भंडारण लागत से संबंधित है।
निम्नलिखित बिंदुओं पर विचार करें -
यदि आपको कम विलंबता के साथ केवल कुछ विशेषताओं तक पहुंच की आवश्यकता है, तो केवल उन लोगों को प्रोजेक्ट करें जिनकी आपको आवश्यकता है। यह भंडारण को कम करता है और लागत लिखता है।
यदि कोई एप्लिकेशन अक्सर कुछ गैर-प्रमुख विशेषताओं तक पहुंचता है, तो उन्हें प्रोजेक्ट करें क्योंकि खपत को स्कैन करने की तुलना में भंडारण की लागत कम होती है।
आप अक्सर एक्सेस की जाने वाली विशेषताओं के बड़े सेट को प्रोजेक्ट कर सकते हैं, हालांकि, यह उच्च भंडारण लागत वहन करती है।
बार-बार लिखने और अपडेट के लिए KEYS_ONLY का उपयोग करें। यह आकार को नियंत्रित करता है, लेकिन फिर भी प्रश्नों पर अच्छा प्रदर्शन प्रदान करता है।
वैश्विक माध्यमिक सूचकांक प्रश्न और स्कैन
आप एक इंडेक्स में एक या कई मदों तक पहुंचने के लिए प्रश्नों का उपयोग कर सकते हैं। आपको सूचकांक और तालिका का नाम, वांछित विशेषताएँ और शर्तें निर्दिष्ट करनी चाहिए; आरोही या अवरोही क्रम में परिणाम वापस करने के विकल्प के साथ।
आप सभी सूचकांक डेटा प्राप्त करने के लिए स्कैन का भी उपयोग कर सकते हैं। इसके लिए टेबल और इंडेक्स नाम की जरूरत होती है। विशिष्ट डेटा प्राप्त करने के लिए आप एक फ़िल्टर एक्सप्रेशन का उपयोग करते हैं।
तालिका और सूचकांक डेटा तुल्यकालन
डायनेमोडीबी स्वचालित रूप से अपनी मूल तालिका के साथ अनुक्रमित पर सिंक्रनाइज़ेशन करता है। आइटम पर प्रत्येक संशोधन संचालन अतुल्यकालिक अद्यतन का कारण बनता है, हालांकि, अनुप्रयोग सीधे अनुक्रमित करने के लिए नहीं लिखते हैं।
आपको सूचकांकों पर डायनेमोडीबी रखरखाव के प्रभाव को समझने की आवश्यकता है। एक इंडेक्स के निर्माण पर, आप मुख्य विशेषताओं और डेटा प्रकारों को निर्दिष्ट करते हैं, जिसका अर्थ है एक लेखन पर, उन डेटा प्रकारों को कुंजी स्कीमा डेटा प्रकारों से मेल खाना चाहिए।
आइटम निर्माण या विलोपन पर, अनुक्रमणिका अंततः एक सुसंगत तरीके से अपडेट होती है, हालांकि, डेटा को दूसरे के एक अंश में प्रचारित किया जाता है (जब तक कि कुछ प्रकार की सिस्टम विफलता नहीं होती है)। आपको इस देरी के लिए आवेदन करना होगा।
Throughput Considerations in Global Secondary Indexes- एकाधिक वैश्विक माध्यमिक अनुक्रमित प्रभाव थ्रूपुट। सूचकांक निर्माण के लिए क्षमता इकाई विनिर्देशों की आवश्यकता होती है, जो तालिका से अलग होती हैं, जिसके परिणामस्वरूप तालिका इकाइयों के बजाय सूचकांक क्षमता इकाइयों का संचालन होता है।
यह थ्रॉटलिंग में परिणाम कर सकता है यदि एक क्वेरी या लिखी गई प्रावधान थ्रूपुट से अधिक है। उपयोग करके थ्रूपुट सेटिंग्स देखेंDescribeTable।
Read Capacity- ग्लोबल सेकेंडरी इंडेक्स अंततः स्थिरता प्रदान करते हैं। प्रश्नों में, डायनेमोडी टेबल के लिए उपयोग किए जाने वाले प्रावधान गणना करता है, जिसमें आइटम आकार के बजाय सूचकांक प्रविष्टि आकार का उपयोग करने का एक अकेला अंतर है। क्वेरी रिटर्न की सीमा 1 एमबी रहती है, जिसमें विशेषता नाम का आकार और प्रत्येक लौटे आइटम में मान शामिल होते हैं।
क्षमता लिखें
जब लिखने का कार्य होता है, तो प्रभावित सूचकांक लेखन इकाइयों का उपभोग करता है। थ्रूपुट लागत लिखो तालिका लिखने में खपत क्षमता इकाइयों और सूचकांक अद्यतन में खपत इकाइयों का योग है। एक सफल लेखन ऑपरेशन के लिए पर्याप्त क्षमता की आवश्यकता होती है, या इसका परिणाम थ्रॉटलिंग में होता है।
लिखने की लागत भी कुछ कारकों पर निर्भर रहती है, जिनमें से कुछ इस प्रकार हैं -
अनुक्रमित विशेषताओं या आइटम अपडेट को परिभाषित करने वाले नए आइटम अपरिभाषित अनुक्रमित विशेषताओं को परिभाषित करते हुए, आइटम को इंडेक्स में जोड़ने के लिए एकल लेखन ऑपरेशन का उपयोग करते हैं।
अनुक्रमित कुंजी विशेषता मान को बदलने वाले अपडेट एक आइटम को हटाने के लिए दो लिखते हैं और एक नया लिखते हैं।
अनुक्रमित विशेषता का एक तालिका लेखन ट्रिगरिंग विलोपन सूचकांक में पुराने आइटम प्रक्षेपण को मिटाने के लिए एकल लेखन का उपयोग करता है।
अद्यतन से पहले और बाद में अनुक्रमणिका में अनुपस्थित आइटम कोई लिखता नहीं है।
अनुक्रमणिका कुंजी स्कीमा में केवल अनुमानित विशेषता मान को बदलने वाले अपडेट, और अनुक्रमित कुंजी विशेषता मान नहीं, इंडेक्स में अनुमानित विशेषताओं के अद्यतन को लिखने के लिए एक लिखने का उपयोग करें।
ये सभी कारक 1KB से कम या इसके बराबर के आइटम आकार को मानते हैं।
वैश्विक माध्यमिक सूचकांक भंडारण
आइटम लिखने पर, DynamoDB स्वचालित रूप से किसी भी सूचकांकों के लिए विशेषताओं के सही सेट की प्रतिलिपि बनाता है जहाँ विशेषताएँ मौजूद होनी चाहिए। यह आपके खाते को तालिका आइटम संग्रहण और विशेषता संग्रहण के लिए चार्ज करके प्रभावित करता है। इन राशियों के योग से परिणाम का उपयोग किया जाता है -
- तालिका प्राथमिक कुंजी का बाइट आकार
- सूचकांक कुंजी विशेषता का बाइट आकार
- अनुमानित विशेषताओं का बाइट आकार
- प्रति इंडेक्स आइटम पर 100 बाइट-ओवरहेड
आप औसत आइटम आकार का आकलन करने और वैश्विक माध्यमिक सूचकांक प्रमुख विशेषताओं के साथ तालिका आइटम की मात्रा से गुणा करके भंडारण की जरूरतों का अनुमान लगा सकते हैं।
डायनेमोबर्ड एक तालिका आइटम के लिए आइटम डेटा नहीं लिखता है जिसमें एक अपरिभाषित विशेषता को एक इंडेक्स विभाजन या सॉर्ट कुंजी के रूप में परिभाषित किया गया है।
ग्लोबल सेकेंडरी इंडेक्स क्रूड
का उपयोग करके वैश्विक माध्यमिक अनुक्रमित के साथ एक तालिका बनाएँ CreateTable ऑपरेशन के साथ जोड़ा गया GlobalSecondaryIndexesपैरामीटर। आपको इंडेक्स विभाजन कुंजी के रूप में सेवा करने के लिए एक विशेषता निर्दिष्ट करनी चाहिए, या इंडेक्स सॉर्ट कुंजी के लिए किसी अन्य का उपयोग करना चाहिए। सभी सूचकांक कुंजी विशेषताएँ स्ट्रिंग, संख्या या बाइनरी स्केलर होनी चाहिए। आपको थ्रूपुट सेटिंग्स भी प्रदान करनी चाहिए, जिसमें शामिल हैReadCapacityUnits तथा WriteCapacityUnits।
उपयोग UpdateTable GlobalSecondaryIndexes पैरामीटर का उपयोग करके एक बार फिर से वैश्विक सेकेंडरी इंडेक्स को मौजूदा तालिकाओं में जोड़ना।
इस ऑपरेशन में, आपको निम्नलिखित जानकारी प्रदान करनी होगी -
- सूचकांक नाम
- मुख्य स्कीमा
- अनुमानित विशेषताएँ
- थ्रूपुट सेटिंग्स
एक वैश्विक माध्यमिक सूचकांक जोड़कर, आइटम की मात्रा, अनुमानित गुण मात्रा, लिखने की क्षमता और गतिविधि लिखने के कारण बड़ी तालिकाओं के साथ पर्याप्त समय लग सकता है। उपयोगCloudWatch प्रक्रिया पर नजर रखने के लिए मैट्रिक्स।
उपयोग DescribeTableएक वैश्विक माध्यमिक सूचकांक के लिए स्थिति की जानकारी प्राप्त करना। यह चार में से एक लौटाता हैIndexStatus GlobalSecondaryIndexes के लिए -
CREATING - यह इंडेक्स के निर्माण चरण और इसकी अनुपलब्धता को इंगित करता है।
ACTIVE - यह उपयोग के लिए सूचकांक की तत्परता को इंगित करता है।
UPDATING - यह थ्रूपुट सेटिंग्स की अद्यतन स्थिति को इंगित करता है।
DELETING - यह सूचकांक की डिलीट स्थिति और उपयोग के लिए इसकी स्थायी अनुपलब्धता को इंगित करता है।
अद्यतन वैश्विक माध्यमिक सूचकांक लोडिंग / बैकफ़िलिंग चरण के दौरान थ्रूपुट सेटिंग्स का प्रावधान करता है (डायनेमोबीडी लेखन गुण एक सूचकांक और जोड़ा / हटाए गए / अपडेट किए गए आइटम पर नज़र रखने के लिए)। उपयोगUpdateTable इस ऑपरेशन को करने के लिए।
आपको याद रखना चाहिए कि बैकफ़िलिंग चरण के दौरान आप अन्य सूचकांकों को जोड़ / हटा नहीं सकते हैं।
ग्लोबल सेकेंडरी इंडेक्स को हटाने के लिए UpdateTable का उपयोग करें। यह प्रति ऑपरेशन केवल एक इंडेक्स को हटाने की अनुमति देता है, हालांकि, आप कई ऑपरेशनों को समवर्ती, पांच तक चला सकते हैं। हटाने की प्रक्रिया पैरेंट टेबल की पढ़ने / लिखने की गतिविधियों को प्रभावित नहीं करती है, लेकिन ऑपरेशन पूरा होने तक आप अन्य सूचकांकों को जोड़ / हटा नहीं सकते हैं।
ग्लोबल सेकेंडरी इंडेक्स के साथ काम करने के लिए जावा का उपयोग करना
CreateTable के माध्यम से एक इंडेक्स के साथ एक तालिका बनाएं। बस एक DynamoDB वर्ग उदाहरण बनाएँ, aCreateTableRequest अनुरोध जानकारी के लिए वर्ग उदाहरण, और CreateTable विधि के लिए अनुरोध ऑब्जेक्ट पास करें।
निम्नलिखित कार्यक्रम एक छोटा उदाहरण है -
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient (
new ProfileCredentialsProvider()));
// Attributes
ArrayList<AttributeDefinition> attributeDefinitions = new
ArrayList<AttributeDefinition>();
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("City")
.withAttributeType("S"));
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("Date")
.withAttributeType("S"));
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("Wind")
.withAttributeType("N"));
// Key schema of the table
ArrayList<KeySchemaElement> tableKeySchema = new ArrayList<KeySchemaElement>();
tableKeySchema.add(new KeySchemaElement()
.withAttributeName("City")
.withKeyType(KeyType.HASH)); //Partition key
tableKeySchema.add(new KeySchemaElement()
.withAttributeName("Date")
.withKeyType(KeyType.RANGE)); //Sort key
// Wind index
GlobalSecondaryIndex windIndex = new GlobalSecondaryIndex()
.withIndexName("WindIndex")
.withProvisionedThroughput(new ProvisionedThroughput()
.withReadCapacityUnits((long) 10)
.withWriteCapacityUnits((long) 1))
.withProjection(new Projection().withProjectionType(ProjectionType.ALL));
ArrayList<KeySchemaElement> indexKeySchema = new ArrayList<KeySchemaElement>();
indexKeySchema.add(new KeySchemaElement()
.withAttributeName("Date")
.withKeyType(KeyType.HASH)); //Partition key
indexKeySchema.add(new KeySchemaElement()
.withAttributeName("Wind")
.withKeyType(KeyType.RANGE)); //Sort key
windIndex.setKeySchema(indexKeySchema);
CreateTableRequest createTableRequest = new CreateTableRequest()
.withTableName("ClimateInfo")
.withProvisionedThroughput(new ProvisionedThroughput()
.withReadCapacityUnits((long) 5)
.withWriteCapacityUnits((long) 1))
.withAttributeDefinitions(attributeDefinitions)
.withKeySchema(tableKeySchema)
.withGlobalSecondaryIndexes(windIndex);
Table table = dynamoDB.createTable(createTableRequest);
System.out.println(table.getDescription());
सूचकांक जानकारी को पुनः प्राप्त करें DescribeTable। सबसे पहले, एक DynamoDB वर्ग उदाहरण बनाएं। फिर एक सूचकांक को लक्षित करने के लिए एक टेबल क्लास का उदाहरण बनाएं। अंत में, तालिका का वर्णन विधि में पास करें।
यहाँ एक छोटा उदाहरण है -
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient (
new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("ClimateInfo");
TableDescription tableDesc = table.describe();
Iterator<GlobalSecondaryIndexDescription> gsiIter =
tableDesc.getGlobalSecondaryIndexes().iterator();
while (gsiIter.hasNext()) {
GlobalSecondaryIndexDescription gsiDesc = gsiIter.next();
System.out.println("Index data " + gsiDesc.getIndexName() + ":");
Iterator<KeySchemaElement> kse7Iter = gsiDesc.getKeySchema().iterator();
while (kseIter.hasNext()) {
KeySchemaElement kse = kseIter.next();
System.out.printf("\t%s: %s\n", kse.getAttributeName(), kse.getKeyType());
}
Projection projection = gsiDesc.getProjection();
System.out.println("\tProjection type: " + projection.getProjectionType());
if (projection.getProjectionType().toString().equals("INCLUDE")) {
System.out.println("\t\tNon-key projected attributes: "
+ projection.getNonKeyAttributes());
}
}
तालिका क्वेरी के साथ अनुक्रमणिका क्वेरी करने के लिए क्वेरी का उपयोग करें। बस डायनामो बी बी श्रेणी उदाहरण, लक्ष्य सूचकांक के लिए एक तालिका वर्ग उदाहरण, विशिष्ट सूचकांक के लिए एक सूचकांक वर्ग उदाहरण, और क्वेरी विधि के लिए सूचकांक और क्वेरी ऑब्जेक्ट पास करें।
बेहतर समझने के लिए निम्नलिखित कोड पर एक नज़र डालें -
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient (
new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("ClimateInfo");
Index index = table.getIndex("WindIndex");
QuerySpec spec = new QuerySpec()
.withKeyConditionExpression("#d = :v_date and Wind = :v_wind")
.withNameMap(new NameMap()
.with("#d", "Date"))
.withValueMap(new ValueMap()
.withString(":v_date","2016-05-15")
.withNumber(":v_wind",0));
ItemCollection<QueryOutcome> items = index.query(spec);
Iterator<Item> iter = items.iterator();
while (iter.hasNext()) {
System.out.println(iter.next().toJSONPretty());
}
निम्नलिखित कार्यक्रम बेहतर समझ के लिए एक बड़ा उदाहरण है -
Note- निम्न प्रोग्राम पहले से बनाए गए डेटा स्रोत को मान सकता है। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
यह उदाहरण ग्रहण आईडीई, AWS क्रेडेंशियल फ़ाइल और AWS टूलकिट का उपयोग ग्रहण Ase Java प्रोजेक्ट के भीतर भी करता है।
import java.util.ArrayList;
import java.util.Iterator;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Index;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.ItemCollection;
import com.amazonaws.services.dynamodbv2.document.QueryOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.spec.QuerySpec;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
import com.amazonaws.services.dynamodbv2.model.AttributeDefinition;
import com.amazonaws.services.dynamodbv2.model.CreateTableRequest;
import com.amazonaws.services.dynamodbv2.model.GlobalSecondaryIndex;
import com.amazonaws.services.dynamodbv2.model.KeySchemaElement;
import com.amazonaws.services.dynamodbv2.model.KeyType;
import com.amazonaws.services.dynamodbv2.model.Projection;
import com.amazonaws.services.dynamodbv2.model.ProvisionedThroughput;
public class GlobalSecondaryIndexSample {
static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient (
new ProfileCredentialsProvider()));
public static String tableName = "Bugs";
public static void main(String[] args) throws Exception {
createTable();
queryIndex("CreationDateIndex");
queryIndex("NameIndex");
queryIndex("DueDateIndex");
}
public static void createTable() {
// Attributes
ArrayList<AttributeDefinition> attributeDefinitions = new
ArrayList<AttributeDefinition>();
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("BugID")
.withAttributeType("S"));
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("Name")
.withAttributeType("S"));
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("CreationDate")
.withAttributeType("S"));
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("DueDate")
.withAttributeType("S"));
// Table Key schema
ArrayList<KeySchemaElement> tableKeySchema = new ArrayList<KeySchemaElement>();
tableKeySchema.add (new KeySchemaElement()
.withAttributeName("BugID")
.withKeyType(KeyType.HASH)); //Partition key
tableKeySchema.add (new KeySchemaElement()
.withAttributeName("Name")
.withKeyType(KeyType.RANGE)); //Sort key
// Indexes' initial provisioned throughput
ProvisionedThroughput ptIndex = new ProvisionedThroughput()
.withReadCapacityUnits(1L)
.withWriteCapacityUnits(1L);
// CreationDateIndex
GlobalSecondaryIndex creationDateIndex = new GlobalSecondaryIndex()
.withIndexName("CreationDateIndex")
.withProvisionedThroughput(ptIndex)
.withKeySchema(new KeySchemaElement()
.withAttributeName("CreationDate")
.withKeyType(KeyType.HASH), //Partition key
new KeySchemaElement()
.withAttributeName("BugID")
.withKeyType(KeyType.RANGE)) //Sort key
.withProjection(new Projection()
.withProjectionType("INCLUDE")
.withNonKeyAttributes("Description", "Status"));
// NameIndex
GlobalSecondaryIndex nameIndex = new GlobalSecondaryIndex()
.withIndexName("NameIndex")
.withProvisionedThroughput(ptIndex)
.withKeySchema(new KeySchemaElement()
.withAttributeName("Name")
.withKeyType(KeyType.HASH), //Partition key
new KeySchemaElement()
.withAttributeName("BugID")
.withKeyType(KeyType.RANGE)) //Sort key
.withProjection(new Projection()
.withProjectionType("KEYS_ONLY"));
// DueDateIndex
GlobalSecondaryIndex dueDateIndex = new GlobalSecondaryIndex()
.withIndexName("DueDateIndex")
.withProvisionedThroughput(ptIndex)
.withKeySchema(new KeySchemaElement()
.withAttributeName("DueDate")
.withKeyType(KeyType.HASH)) //Partition key
.withProjection(new Projection()
.withProjectionType("ALL"));
CreateTableRequest createTableRequest = new CreateTableRequest()
.withTableName(tableName)
.withProvisionedThroughput( new ProvisionedThroughput()
.withReadCapacityUnits( (long) 1)
.withWriteCapacityUnits( (long) 1))
.withAttributeDefinitions(attributeDefinitions)
.withKeySchema(tableKeySchema)
.withGlobalSecondaryIndexes(creationDateIndex, nameIndex, dueDateIndex);
System.out.println("Creating " + tableName + "...");
dynamoDB.createTable(createTableRequest);
// Pause for active table state
System.out.println("Waiting for ACTIVE state of " + tableName);
try {
Table table = dynamoDB.getTable(tableName);
table.waitForActive();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public static void queryIndex(String indexName) {
Table table = dynamoDB.getTable(tableName);
System.out.println
("\n*****************************************************\n");
System.out.print("Querying index " + indexName + "...");
Index index = table.getIndex(indexName);
ItemCollection<QueryOutcome> items = null;
QuerySpec querySpec = new QuerySpec();
if (indexName == "CreationDateIndex") {
System.out.println("Issues filed on 2016-05-22");
querySpec.withKeyConditionExpression("CreationDate = :v_date and begins_with
(BugID, :v_bug)")
.withValueMap(new ValueMap()
.withString(":v_date","2016-05-22")
.withString(":v_bug","A-"));
items = index.query(querySpec);
} else if (indexName == "NameIndex") {
System.out.println("Compile error");
querySpec.withKeyConditionExpression("Name = :v_name and begins_with
(BugID, :v_bug)")
.withValueMap(new ValueMap()
.withString(":v_name","Compile error")
.withString(":v_bug","A-"));
items = index.query(querySpec);
} else if (indexName == "DueDateIndex") {
System.out.println("Items due on 2016-10-15");
querySpec.withKeyConditionExpression("DueDate = :v_date")
.withValueMap(new ValueMap()
.withString(":v_date","2016-10-15"));
items = index.query(querySpec);
} else {
System.out.println("\nInvalid index name");
return;
}
Iterator<Item> iterator = items.iterator();
System.out.println("Query: getting result...");
while (iterator.hasNext()) {
System.out.println(iterator.next().toJSONPretty());
}
}
}
कुछ एप्लिकेशन केवल प्राथमिक कुंजी के साथ क्वेरी करते हैं, लेकिन कुछ स्थितियों को वैकल्पिक सॉर्ट कुंजी से लाभ होता है। एक या कई स्थानीय माध्यमिक अनुक्रमित बनाकर अपने आवेदन को एक विकल्प चुनें।
जटिल डेटा एक्सेस आवश्यकताएं, जैसे कि लाखों आइटम का मुकाबला करना, अधिक कुशल क्वेरी / स्कैन करना आवश्यक है। स्थानीय माध्यमिक सूचकांक एक विभाजन कुंजी मूल्य के लिए एक वैकल्पिक सॉर्ट कुंजी प्रदान करते हैं। वे सभी या कुछ तालिका विशेषताओं की प्रतियां भी रखते हैं। वे तालिका विभाजन कुंजी द्वारा डेटा को व्यवस्थित करते हैं, लेकिन एक अलग प्रकार की कुंजी का उपयोग करते हैं।
स्थानीय सेकेंडरी इंडेक्स का उपयोग पूरे टेबल स्कैन की आवश्यकता को हटाता है, और सॉर्ट कुंजी का उपयोग करके एक सरल और त्वरित क्वेरी की अनुमति देता है।
सभी स्थानीय माध्यमिक अनुक्रमितों को कुछ शर्तों को पूरा करना होगा -
- आइडेंटिकल पार्टीशन की और सोर्स टेबल पार्टीशन की।
- केवल एक स्केलर विशेषता की एक सॉर्ट कुंजी।
- स्रोत तालिका की कुंजी एक गैर-कुंजी विशेषता के रूप में प्रमुख अभिनय को सॉर्ट करती है।
सभी स्थानीय माध्यमिक सूचकांक स्वचालित रूप से विभाजन और पैरेंट टेबल से कुंजियों को क्रमबद्ध करते हैं। प्रश्नों में, इसका मतलब है कि अनुमानित विशेषताओं का कुशल जमावड़ा, और उन विशेषताओं की पुनर्प्राप्ति भी जो अनुमानित नहीं हैं।
एक स्थानीय सेकेंडरी इंडेक्स के लिए स्टोरेज लिमिट 10GB प्रति पार्टीशन की वैल्यू पर रहती है, जिसमें सभी टेबल आइटम और एक डिवीजन की वैल्यू शेयर करने वाले इंडेक्स आइटम शामिल होते हैं।
एक विशेषता पेश करना
कुछ ऑपरेशनों को जटिलता के कारण अतिरिक्त रीड / लाने की आवश्यकता होती है। ये ऑपरेशन पर्याप्त थ्रूपुट का उपभोग कर सकते हैं। प्रोजेक्शन आपको इन विशेषताओं को अलग करके महंगे प्रश्नों से बचने और समृद्ध क्वेरी करने की अनुमति देता है। याद रखें कि अनुमानों में एक द्वितीयक सूचकांक में कॉपी की गई विशेषताएँ शामिल हैं।
द्वितीयक सूचकांक बनाते समय, आप अनुमानित विशेषताओं को निर्दिष्ट करते हैं। डायनेमोडीबी द्वारा दिए गए तीन विकल्पों को याद करें:KEYS_ONLY, INCLUDE, and ALL।
जब प्रक्षेपण में कुछ विशेषताओं के लिए चुनते हैं, तो संबंधित लागत ट्रेडऑफ़ पर विचार करें -
यदि आप आवश्यक विशेषताओं का केवल एक छोटा सा सेट करते हैं, तो आप नाटकीय रूप से भंडारण लागत को कम करते हैं।
यदि आप अक्सर गैर-प्रमुख विशेषताओं को एक्सेस करते हैं, तो आप स्टोरेज लागत के साथ स्कैन लागतों को ऑफसेट करते हैं।
यदि आप अधिकांश या सभी गैर-प्रमुख विशेषताओं को प्रोजेक्ट करते हैं, तो यह लचीलेपन को अधिकतम करता है और थ्रूपुट (कोई पुनर्प्राप्ति) को कम करता है; हालाँकि, भंडारण लागत में वृद्धि होती है।
यदि आप बार-बार लिखने / अपडेट करने और असंगत प्रश्नों के लिए KEYS_ONLY प्रोजेक्ट करते हैं, तो यह आकार को कम करता है, लेकिन क्वेरी तैयारी को बनाए रखता है।
स्थानीय माध्यमिक सूचकांक निर्माण
उपयोग LocalSecondaryIndexसिंगल या मल्टीपल लोकल सेकेंडरी इंडेक्स बनाने के लिए क्रिएटटेबल का पैरामीटर। आपको सॉर्ट कुंजी के लिए एक गैर-कुंजी विशेषता निर्दिष्ट करनी होगी। टेबल निर्माण पर, आप स्थानीय माध्यमिक सूचकांक बनाते हैं। डिलीट करने पर आप इन इंडेक्स को डिलीट कर देते हैं।
एक स्थानीय माध्यमिक सूचकांक के साथ तालिकाओं को प्रति विभाजन कुंजी मूल्य में 10GB की सीमा का पालन करना चाहिए, लेकिन किसी भी आइटम को संग्रहीत कर सकते हैं।
स्थानीय माध्यमिक सूचकांक प्रश्न और स्कैन
स्थानीय माध्यमिक अनुक्रमितों पर एक क्वेरी ऑपरेशन सभी मदों को एक मिलान विभाजन कुंजी मूल्य के साथ लौटाता है जब सूचकांक में कई आइटम प्रमुख मूल्यों को साझा करते हैं। मैचिंग आइटम एक निश्चित क्रम में वापस नहीं आते हैं। स्थानीय माध्यमिक अनुक्रमितों के लिए क्वेरीज़, नवीनतम मूल्यों को वितरित करने वाले जोरदार लगातार रीड्स के साथ अंतिम या मजबूत स्थिरता का उपयोग करती हैं।
एक स्कैन ऑपरेशन सभी स्थानीय माध्यमिक सूचकांक डेटा लौटाता है। स्कैन के लिए आपको एक टेबल और इंडेक्स नाम प्रदान करने की आवश्यकता होती है, और डेटा को छोड़ने के लिए एक फिल्टर एक्सप्रेशन का उपयोग करने की अनुमति देता है।
आइटम लेखन
एक स्थानीय माध्यमिक सूचकांक के निर्माण पर, आप एक सॉर्ट कुंजी विशेषता और उसके डेटा प्रकार को निर्दिष्ट करते हैं। जब आप एक आइटम लिखते हैं, तो उसका प्रकार कुंजी स्कीमा के डेटा प्रकार से मेल खाना चाहिए यदि आइटम किसी इंडेक्स कुंजी की विशेषता को परिभाषित करता है।
डायनेमोबीडी टेबल आइटम और स्थानीय माध्यमिक इंडेक्स आइटम पर एक-से-एक संबंध आवश्यकताओं को नहीं लगाता है। कई स्थानीय माध्यमिक अनुक्रमित तालिकाएँ कम लिखने वालों की तुलना में अधिक लेखन लागत लेती हैं।
स्थानीय माध्यमिक सूचकांक में थ्रूपुट विचार
एक क्वेरी की क्षमता खपत डेटा एक्सेस की प्रकृति पर निर्भर करती है। अंततः अंतिम रीडिंग में आधे यूनिट की तुलना में एक यूनिट का उपयोग करके दृढ़ता से लगातार रीडिंग के साथ क्वेरीज़ या तो सुसंगत या मजबूत स्थिरता का उपयोग करती हैं।
परिणाम सीमाओं में अधिकतम 1MB आकार शामिल है। परिणाम आकार निकटतम 4KB तक गोल अनुक्रमणिका आइटम आकार के योग से आते हैं, और मिलान तालिका आइटम आकार भी निकटतम 4KB तक गोल है।
लिखित क्षमता की खपत प्रावधानित इकाइयों के भीतर ही रहती है। तालिका लेखन में खपत इकाइयों की राशि और सूचकांकों को अपडेट करने में खपत इकाइयों की कुल संख्या का पता लगाकर कुल प्रावधानित लागत की गणना करें।
आप लागत को प्रभावित करने वाले प्रमुख कारकों पर भी विचार कर सकते हैं, जिनमें से कुछ हो सकते हैं -
जब आप अनुक्रमित विशेषता को परिभाषित करने वाले आइटम को लिखते हैं या किसी अपरिभाषित अनुक्रमित विशेषता को परिभाषित करने के लिए आइटम को अपडेट करते हैं, तो एकल लेखन ऑपरेशन होता है।
जब तालिका अद्यतन एक अनुक्रमित कुंजी विशेषता मान को बदलता है, तो दो राइट्स डिलीट होते हैं और फिर - एक आइटम जोड़ते हैं।
जब कोई लेखन अनुक्रमित विशेषता को हटाने का कारण बनता है, तो एक लेखन पुराने आइटम प्रक्षेपण को हटाने के लिए होता है।
जब कोई आइटम इंडेक्स के अपडेट से पहले या बाद में मौजूद नहीं होता है, तो कोई लिखता नहीं है।
स्थानीय माध्यमिक सूचकांक भंडारण
एक टेबल आइटम लिखने पर, DynamoDB स्वचालित रूप से आवश्यक स्थानीय माध्यमिक अनुक्रमित करने के लिए सेट सही विशेषता की प्रतिलिपि बनाता है। इससे आपका अकाउंट चार्ज हो जाता है। अंतरिक्ष ने तालिका प्राथमिक कुंजी बाइट आकार, सूचकांक कुंजी विशेषता बाइट आकार, किसी भी वर्तमान अनुमानित विशेषता बाइट आकार और प्रत्येक सूचकांक आइटम के लिए ओवरहेड में 100 बाइट्स के योग से परिणाम का उपयोग किया।
अनुमान संग्रहण औसत सूचकांक आइटम आकार का आकलन करके और तालिका आइटम मात्रा से गुणा करके प्राप्त किया जाता है।
जावा का उपयोग स्थानीय माध्यमिक सूचकांक के साथ काम करने के लिए
पहली बार एक डायनॉम्बीडी श्रेणी का उदाहरण बनाकर एक स्थानीय माध्यमिक सूचकांक बनाएं। फिर, आवश्यक अनुरोध जानकारी के साथ CreateTableRequest वर्ग का उदाहरण बनाएँ। अंत में, CreateTable पद्धति का उपयोग करें।
उदाहरण
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
String tableName = "Tools";
CreateTableRequest createTableRequest = new
CreateTableRequest().withTableName(tableName);
//Provisioned Throughput
createTableRequest.setProvisionedThroughput (
new ProvisionedThroughput()
.withReadCapacityUnits((long)5)
.withWriteCapacityUnits(( long)5));
//Attributes
ArrayList<AttributeDefinition> attributeDefinitions =
new ArrayList<AttributeDefinition>();
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("Make")
.withAttributeType("S"));
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("Model")
.withAttributeType("S"));
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("Line")
.withAttributeType("S"));
createTableRequest.setAttributeDefinitions(attributeDefinitions);
//Key Schema
ArrayList<KeySchemaElement> tableKeySchema = new
ArrayList<KeySchemaElement>();
tableKeySchema.add(new KeySchemaElement()
.withAttributeName("Make")
.withKeyType(KeyType.HASH)); //Partition key
tableKeySchema.add(new KeySchemaElement()
.withAttributeName("Model")
.withKeyType(KeyType.RANGE)); //Sort key
createTableRequest.setKeySchema(tableKeySchema);
ArrayList<KeySchemaElement> indexKeySchema = new
ArrayList<KeySchemaElement>();
indexKeySchema.add(new KeySchemaElement()
.withAttributeName("Make")
.withKeyType(KeyType.HASH)); //Partition key
indexKeySchema.add(new KeySchemaElement()
.withAttributeName("Line")
.withKeyType(KeyType.RANGE)); //Sort key
Projection projection = new Projection()
.withProjectionType(ProjectionType.INCLUDE);
ArrayList<String> nonKeyAttributes = new ArrayList<String>();
nonKeyAttributes.add("Type");
nonKeyAttributes.add("Year");
projection.setNonKeyAttributes(nonKeyAttributes);
LocalSecondaryIndex localSecondaryIndex = new LocalSecondaryIndex()
.withIndexName("ModelIndex")
.withKeySchema(indexKeySchema)
.withProjection(p rojection);
ArrayList<LocalSecondaryIndex> localSecondaryIndexes = new
ArrayList<LocalSecondaryIndex>();
localSecondaryIndexes.add(localSecondaryIndex);
createTableRequest.setLocalSecondaryIndexes(localSecondaryIndexes);
Table table = dynamoDB.createTable(createTableRequest);
System.out.println(table.getDescription());
वर्णन विधि के साथ एक स्थानीय माध्यमिक सूचकांक के बारे में जानकारी प्राप्त करें। बस डायनामो बी बी श्रेणी उदाहरण बनाएँ, एक टेबल क्लास उदाहरण बनाएँ, और वर्णन विधि में तालिका पास करें।
उदाहरण
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
String tableName = "Tools";
Table table = dynamoDB.getTable(tableName);
TableDescription tableDescription = table.describe();
List<LocalSecondaryIndexDescription> localSecondaryIndexes =
tableDescription.getLocalSecondaryIndexes();
Iterator<LocalSecondaryIndexDescription> lsiIter =
localSecondaryIndexes.iterator();
while (lsiIter.hasNext()) {
LocalSecondaryIndexDescription lsiDescription = lsiIter.next();
System.out.println("Index info " + lsiDescription.getIndexName() + ":");
Iterator<KeySchemaElement> kseIter = lsiDescription.getKeySchema().iterator();
while (kseIter.hasNext()) {
KeySchemaElement kse = kseIter.next();
System.out.printf("\t%s: %s\n", kse.getAttributeName(), kse.getKeyType());
}
Projection projection = lsiDescription.getProjection();
System.out.println("\tProjection type: " + projection.getProjectionType());
if (projection.getProjectionType().toString().equals("INCLUDE")) {
System.out.println("\t\tNon-key projected attributes: " +
projection.getNonKeyAttributes());
}
}
तालिका क्वेरी के समान चरणों का उपयोग करके किसी क्वेरी को निष्पादित करें। केवल डायनामो बी बी श्रेणी उदाहरण, एक टेबल क्लास उदाहरण, एक इंडेक्स क्लास इंस्टेंस, एक क्वेरी ऑब्जेक्ट, और क्वेरी विधि का उपयोग करें।
उदाहरण
DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
String tableName = "Tools";
Table table = dynamoDB.getTable(tableName);
Index index = table.getIndex("LineIndex");
QuerySpec spec = new QuerySpec()
.withKeyConditionExpression("Make = :v_make and Line = :v_line")
.withValueMap(new ValueMap()
.withString(":v_make", "Depault")
.withString(":v_line", "SuperSawz"));
ItemCollection<QueryOutcome> items = index.query(spec);
Iterator<Item> itemsIter = items.iterator();
while (itemsIter.hasNext()) {
Item item = itemsIter.next();
System.out.println(item.toJSONPretty());
}
आप निम्न उदाहरण की समीक्षा भी कर सकते हैं।
Note- निम्नलिखित उदाहरण पहले से बनाए गए डेटा स्रोत को मान सकते हैं। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ तालिकाओं, या अन्य संदर्भित स्रोत)।
निम्नलिखित उदाहरण ग्रहण आईडीई, एक एडब्ल्यूएस क्रेडेंशियल फ़ाइल और एक एडब्ल्यूएस जावा प्रोजेक्ट के भीतर एडब्ल्यूएस टूलकिट का भी उपयोग करता है।
उदाहरण
import java.util.ArrayList;
import java.util.Iterator;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Index;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.ItemCollection;
import com.amazonaws.services.dynamodbv2.document.PutItemOutcome;
import com.amazonaws.services.dynamodbv2.document.QueryOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.spec.QuerySpec;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
import com.amazonaws.services.dynamodbv2.model.AttributeDefinition;
import com.amazonaws.services.dynamodbv2.model.CreateTableRequest;
import com.amazonaws.services.dynamodbv2.model.KeySchemaElement;
import com.amazonaws.services.dynamodbv2.model.KeyType;
import com.amazonaws.services.dynamodbv2.model.LocalSecondaryIndex;
import com.amazonaws.services.dynamodbv2.model.Projection;
import com.amazonaws.services.dynamodbv2.model.ProjectionType;
import com.amazonaws.services.dynamodbv2.model.ProvisionedThroughput;
import com.amazonaws.services.dynamodbv2.model.ReturnConsumedCapacity;
import com.amazonaws.services.dynamodbv2.model.Select;
public class LocalSecondaryIndexSample {
static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
new ProfileCredentialsProvider()));
public static String tableName = "ProductOrders";
public static void main(String[] args) throws Exception {
createTable();
query(null);
query("IsOpenIndex");
query("OrderCreationDateIndex");
}
public static void createTable() {
CreateTableRequest createTableRequest = new CreateTableRequest()
.withTableName(tableName)
.withProvisionedThroughput(new ProvisionedThroughput()
.withReadCapacityUnits((long) 1)
.withWriteCapacityUnits((long) 1));
// Table partition and sort keys attributes
ArrayList<AttributeDefinition> attributeDefinitions = new
ArrayList<AttributeDefinition>();
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("CustomerID")
.withAttributeType("S"));
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("OrderID")
.withAttributeType("N"));
// Index primary key attributes
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("OrderDate")
.withAttributeType("N"));
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("OpenStatus")
.withAttributeType("N"));
createTableRequest.setAttributeDefinitions(attributeDefinitions);
// Table key schema
ArrayList<KeySchemaElement> tableKeySchema = new
ArrayList<KeySchemaElement>();
tableKeySchema.add(new KeySchemaElement()
.withAttributeName("CustomerID")
.withKeyType(KeyType.HASH)); //Partition key
tableKeySchema.add(new KeySchemaElement()
.withAttributeName("OrderID")
.withKeyType(KeyType.RANGE)); //Sort key
createTableRequest.setKeySchema(tableKeySchema);
ArrayList<LocalSecondaryIndex> localSecondaryIndexes = new
ArrayList<LocalSecondaryIndex>();
// OrderDateIndex
LocalSecondaryIndex orderDateIndex = new LocalSecondaryIndex()
.withIndexName("OrderDateIndex");
// OrderDateIndex key schema
ArrayList<KeySchemaElement> indexKeySchema = new
ArrayList<KeySchemaElement>();
indexKeySchema.add(new KeySchemaElement()
.withAttributeName("CustomerID")
.withKeyType(KeyType.HASH)); //Partition key
indexKeySchema.add(new KeySchemaElement()
.withAttributeName("OrderDate")
.withKeyType(KeyType.RANGE)); //Sort key
orderDateIndex.setKeySchema(indexKeySchema);
// OrderCreationDateIndex projection w/attributes list
Projection projection = new Projection()
.withProjectionType(ProjectionType.INCLUDE);
ArrayList<String> nonKeyAttributes = new ArrayList<String>();
nonKeyAttributes.add("ProdCat");
nonKeyAttributes.add("ProdNomenclature");
projection.setNonKeyAttributes(nonKeyAttributes);
orderCreationDateIndex.setProjection(projection);
localSecondaryIndexes.add(orderDateIndex);
// IsOpenIndex
LocalSecondaryIndex isOpenIndex = new LocalSecondaryIndex()
.withIndexName("IsOpenIndex");
// OpenStatusIndex key schema
indexKeySchema = new ArrayList<KeySchemaElement>();
indexKeySchema.add(new KeySchemaElement()
.withAttributeName("CustomerID")
.withKeyType(KeyType.HASH)); //Partition key
indexKeySchema.add(new KeySchemaElement()
.withAttributeName("OpenStatus")
.withKeyType(KeyType.RANGE)); //Sort key
// OpenStatusIndex projection
projection = new Projection() .withProjectionType(ProjectionType.ALL);
OpenStatusIndex.setKeySchema(indexKeySchema);
OpenStatusIndex.setProjection(projection);
localSecondaryIndexes.add(OpenStatusIndex);
// Put definitions in CreateTable request
createTableRequest.setLocalSecondaryIndexes(localSecondaryIndexes);
System.out.println("Spawning table " + tableName + "...");
System.out.println(dynamoDB.createTable(createTableRequest));
// Pause for ACTIVE status
System.out.println("Waiting for ACTIVE table:" + tableName);
try {
Table table = dynamoDB.getTable(tableName);
table.waitForActive();
} catch (InterruptedException e) {
e.printStackTrace();
}
}
public static void query(String indexName) {
Table table = dynamoDB.getTable(tableName);
System.out.println("\n*************************************************\n");
System.out.println("Executing query on" + tableName);
QuerySpec querySpec = new QuerySpec()
.withConsistentRead(true)
.withScanIndexForward(true)
.withReturnConsumedCapacity(ReturnConsumedCapacity.TOTAL);
if (indexName == "OpenStatusIndex") {
System.out.println("\nEmploying index: '" + indexName
+ "' open orders for this customer.");
System.out.println(
"Returns only user-specified attribute list\n");
Index index = table.getIndex(indexName);
querySpec.withKeyConditionExpression("CustomerID = :v_custmid and
OpenStatus = :v_openstat")
.withValueMap(new ValueMap()
.withString(":v_custmid", "[email protected]")
.withNumber(":v_openstat", 1));
querySpec.withProjectionExpression(
"OrderDate, ProdCat, ProdNomenclature, OrderStatus");
ItemCollection<QueryOutcome> items = index.query(querySpec);
Iterator<Item> iterator = items.iterator();
System.out.println("Printing query results...");
while (iterator.hasNext()) {
System.out.println(iterator.next().toJSONPretty());
}
} else if (indexName == "OrderDateIndex") {
System.out.println("\nUsing index: '" + indexName
+ "': this customer's orders placed after 05/22/2016.");
System.out.println("Projected attributes are returned\n");
Index index = table.getIndex(indexName);
querySpec.withKeyConditionExpression("CustomerID = :v_custmid and OrderDate
>= :v_ordrdate")
.withValueMap(new ValueMap()
.withString(":v_custmid", "[email protected]")
.withNumber(":v_ordrdate", 20160522));
querySpec.withSelect(Select.ALL_PROJECTED_ATTRIBUTES);
ItemCollection<QueryOutcome> items = index.query(querySpec);
Iterator<Item> iterator = items.iterator();
System.out.println("Printing query results...");
while (iterator.hasNext()) {
System.out.println(iterator.next().toJSONPretty());
}
} else {
System.out.println("\nNo index: All Jane's orders by OrderID:\n");
querySpec.withKeyConditionExpression("CustomerID = :v_custmid")
.withValueMap(new ValueMap()
.withString(":v_custmid", "[email protected]"));
ItemCollection<QueryOutcome> items = table.query(querySpec);
Iterator<Item> iterator = items.iterator();
System.out.println("Printing query results...");
while (iterator.hasNext()) {
System.out.println(iterator.next().toJSONPretty());
}
}
}
}
डायनेमोडी एकत्रीकरण कार्य प्रदान नहीं करता है। इन कार्यों को करने के लिए आपको प्रश्नों, स्कैन, सूचकांकों और मिश्रित उपकरणों का रचनात्मक उपयोग करना चाहिए। इस सब में, इन परिचालनों में प्रश्नों / स्कैन का थ्रूपुट व्यय भारी हो सकता है।
आपके पास अपनी पसंदीदा डायनमोबी कोडिंग भाषा के लिए पुस्तकालयों और अन्य उपकरणों का उपयोग करने का विकल्प भी है। उपयोग करने से पहले डायनमोबी के साथ उनकी संगतता सुनिश्चित करें।
अधिकतम या न्यूनतम गणना करें
परिणामों के आरोही / अवरोही भंडारण क्रम, सीमा पैरामीटर और किसी भी पैरामीटर का उपयोग करें, जो उच्चतम और निम्नतम मानों को खोजने के लिए क्रम निर्धारित करते हैं।
उदाहरण के लिए -
Map<String, AttributeValue> eaval = new HashMap<>();
eaval.put(":v1", new AttributeValue().withS("hashval"));
queryExpression = new DynamoDBQueryExpression<Table>()
.withIndexName("yourindexname")
.withKeyConditionExpression("HK = :v1")
.withExpressionAttributeValues(values)
.withScanIndexForward(false); //descending order
queryExpression.setLimit(1);
QueryResultPage<Lookup> res =
dynamoDBMapper.queryPage(Table.class, queryExpression);
गणना की गणना
उपयोग DescribeTableहालाँकि, टेबल आइटम्स की गिनती प्राप्त करने के लिए, ध्यान दें कि यह बासी डेटा प्रदान करता है। इसके अलावा, जावा का उपयोग करेंgetScannedCount method।
उपयोग LastEvaluatedKey यह सुनिश्चित करने के लिए कि यह सभी परिणाम प्रदान करता है।
उदाहरण के लिए -
ScanRequest scanRequest = new ScanRequest().withTableName(yourtblName);
ScanResult yourresult = client.scan(scanRequest);
System.out.println("#items:" + yourresult.getScannedCount());
औसत और सम की गणना
प्रसंस्करण से पहले मूल्यों को पुनः प्राप्त करने और फ़िल्टर करने के लिए सूचकांकों और एक क्वेरी / स्कैन का उपयोग करें। फिर बस एक वस्तु के माध्यम से उन मूल्यों पर काम करते हैं।
DynamoDB उन क्रेडेंशियल्स का उपयोग करता है जिन्हें आप अनुरोधों को प्रमाणित करने के लिए प्रदान करते हैं। इन क्रेडेंशियल की आवश्यकता होती है और इसमें AWS रिसोर्स एक्सेस की अनुमति शामिल होनी चाहिए। ये अनुमतियाँ वस्तुतः डायनेमोडीबी के हर पहलू को एक ऑपरेशन या कार्यक्षमता की मामूली विशेषताओं तक ले जाती हैं।
अनुमतियाँ के प्रकार
इस खंड में, हम डायनामोडीबी में विभिन्न अनुमतियों और संसाधन पहुंच के बारे में चर्चा करेंगे।
उपयोगकर्ताओं का प्रमाणीकरण
साइनअप पर, आपने एक पासवर्ड और ईमेल प्रदान किया, जो रूट क्रेडेंशियल के रूप में काम करता है। DynamoDB इस डेटा को आपके AWS खाते के साथ जोड़ता है, और इसका उपयोग सभी संसाधनों तक पूरी पहुँच प्रदान करने के लिए करता है।
AWS आपको सलाह देता है कि आप अपने रूट क्रेडेंशियल्स का उपयोग केवल एक प्रशासन खाते के निर्माण के लिए करें। इससे आप कम विशेषाधिकार वाले IAM खाते / उपयोगकर्ता बना सकते हैं। IAM उपयोगकर्ता IAM सेवा के साथ अन्य खाते हैं। उनकी पहुँच अनुमतियाँ / विशेषाधिकार सुरक्षित पृष्ठ तक पहुँच और तालिका संशोधन जैसी कुछ कस्टम अनुमतियाँ शामिल हैं।
पहुंच कुंजी अतिरिक्त खातों और पहुंच के लिए एक और विकल्प प्रदान करती है। पहुँच प्रदान करने के लिए उनका उपयोग करें, और कुछ स्थितियों में मैन्युअल अनुदान देने से भी बचें। फ़ेडरेटेड उपयोगकर्ता पहचान प्रदाता के माध्यम से पहुंच की अनुमति देकर एक और विकल्प प्रदान करते हैं।
शासन प्रबंध
AWS संसाधन किसी खाते के स्वामित्व में रहते हैं। अनुमतियाँ नीतियाँ स्पॉन या पहुँच संसाधनों के लिए दी गई अनुमतियों को नियंत्रित करती हैं। व्यवस्थापक IAM पहचान, अर्थ भूमिकाओं, समूहों, उपयोगकर्ताओं और सेवाओं के साथ नीतियों को अनुमति देते हैं। वे संसाधनों के लिए अनुमति भी देते हैं।
अनुमतियाँ उपयोगकर्ताओं, संसाधनों और कार्यों को निर्दिष्ट करती हैं। नोट प्रशासक केवल प्रशासक विशेषाधिकारों के साथ खाते हैं।
संचालन और संसाधन
डायनामोबीडी में टेबल्स मुख्य संसाधन बने हुए हैं। उप-स्रोत अतिरिक्त संसाधनों, जैसे, धाराओं और सूचकांकों के रूप में कार्य करते हैं। ये संसाधन अद्वितीय नामों का उपयोग करते हैं, जिनमें से कुछ निम्नलिखित तालिका में उल्लिखित हैं -
प्रकार | ARN (अमेज़न संसाधन नाम) |
---|---|
धारा | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम / धारा / धारा-लेबल |
सूची | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम / सूचकांक / सूचकांक नाम |
टेबल | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
स्वामित्व
संसाधन स्वामी को AWS खाते के रूप में परिभाषित किया जाता है जिसने संसाधन निर्माण में संसाधन प्रमाणीकरण के लिए जिम्मेदार संसाधन, या प्रमुख संस्था खाता को जन्म दिया। विचार करें कि डायनमोफ के वातावरण में यह कैसे कार्य करता है -
तालिका बनाने के लिए रूट क्रेडेंशियल्स का उपयोग करने में, आपका खाता संसाधन स्वामी बना रहता है।
एक IAM उपयोगकर्ता बनाने और तालिका बनाने के लिए उपयोगकर्ता की अनुमति देने में, आपका खाता संसाधन स्वामी बना रहता है।
IAM उपयोगकर्ता बनाने और उपयोगकर्ता को अनुदान देने में, और भूमिका संभालने में सक्षम कोई भी व्यक्ति, तालिका बनाने की अनुमति देता है, आपका खाता संसाधन स्वामी बना रहता है।
संसाधन एक्सेस प्रबंधित करें
उपयोग के प्रबंधन के लिए मुख्य रूप से उपयोगकर्ताओं और संसाधन पहुंच का वर्णन करने वाली अनुमतियों की नीति पर ध्यान देना आवश्यक है। आप नीतियों को IAM पहचान या संसाधनों से जोड़ते हैं। हालाँकि, डायनेमोडीबी केवल IAM / पहचान नीतियों का समर्थन करता है।
पहचान-आधारित (IAM) नीतियां आपको निम्नलिखित तरीकों से विशेषाधिकार प्रदान करने की अनुमति देती हैं -
- उपयोगकर्ताओं या समूहों को अनुमति संलग्न करें।
- क्रॉस-अकाउंट अनुमतियों के लिए भूमिकाओं के लिए अनुमतियाँ संलग्न करें।
अन्य AWS संसाधन-आधारित नीतियों की अनुमति देते हैं। ये नीतियां S3 बाल्टी जैसी चीजों तक पहुंच की अनुमति देती हैं।
नीति तत्व
नीतियां क्रियाओं, प्रभावों, संसाधनों और प्रिंसिपलों को परिभाषित करती हैं; और इन कार्यों को करने की अनुमति प्रदान करें।
Note - एपीआई कार्रवाइयों को कई कार्यों के लिए अनुमति की आवश्यकता हो सकती है।
निम्नलिखित नीति तत्वों पर करीब से नज़र डालें -
Resource - एक ARN इसकी पहचान करता है।
Action - कीवर्ड इन संसाधन संचालन की पहचान करते हैं, और अनुमति देने या अस्वीकार करने के लिए।
Effect - यह एक कार्रवाई के लिए एक उपयोगकर्ता के अनुरोध के लिए प्रभाव को निर्दिष्ट करता है, जिसका अर्थ डिफ़ॉल्ट के रूप में इनकार के साथ अनुमति या इनकार है।
Principal - यह पॉलिसी से जुड़े उपयोगकर्ता की पहचान करता है।
शर्तेँ
अनुमतियाँ देने में, आप उन शर्तों को निर्दिष्ट कर सकते हैं, जब नीतियाँ किसी विशेष तिथि पर सक्रिय हो जाती हैं। स्थिति कुंजियों के साथ शर्तों को व्यक्त करें, जिसमें AWS प्रणालीबद्ध कुंजी और DynamoDB कुंजी शामिल हैं। इन कुंजियों पर बाद में ट्यूटोरियल में विस्तार से चर्चा की गई है।
कंसोल अनुमतियाँ
एक उपयोगकर्ता को कंसोल का उपयोग करने के लिए कुछ बुनियादी अनुमतियों की आवश्यकता होती है। उन्हें अन्य मानक सेवाओं में कंसोल के लिए अनुमतियों की भी आवश्यकता होती है -
- CloudWatch
- डेटा पाइपलाइन
- पहचान और पहुंच प्रबंधन
- अधिसूचना सेवा
- Lambda
यदि IAM नीति बहुत सीमित साबित होती है, तो उपयोगकर्ता कंसोल का प्रभावी ढंग से उपयोग नहीं कर सकता है। इसके अलावा, आपको केवल CLI या API कॉल करने वालों के लिए उपयोगकर्ता अनुमतियों के बारे में चिंता करने की आवश्यकता नहीं है।
आम उपयोग Iam नीतियां
एडब्ल्यूएस स्टैंडअलोन IAM प्रबंधित नीतियों के साथ अनुमतियों में सामान्य संचालन को शामिल करता है। वे महत्वपूर्ण अनुमति प्रदान करते हैं जो आपको गहरी जांच से बचने की अनुमति देता है कि आपको क्या अनुदान देना चाहिए।
उनमें से कुछ इस प्रकार हैं -
AmazonDynamoDBReadOnlyAccess - यह कंसोल के माध्यम से रीड-ओनली एक्सेस देता है।
AmazonDynamoDBFullAccess - यह कंसोल के जरिए पूरा एक्सेस देता है।
AmazonDynamoDBFullAccesswithDataPipeline - यह कंसोल के माध्यम से पूर्ण पहुंच देता है और डेटा पाइपलाइन के साथ निर्यात / आयात की अनुमति देता है।
आप कस्टम नीतियां भी बना सकते हैं।
अनुदान देना: शेल का उपयोग करना
आप जावास्क्रिप्ट शेल के साथ अनुमति दे सकते हैं। निम्नलिखित कार्यक्रम एक विशिष्ट अनुमति नीति दिखाता है -
{
"Version": "2016-05-22",
"Statement": [
{
"Sid": "DescribeQueryScanToolsTable",
"Effect": "Deny",
"Action": [
"dynamodb:DescribeTable",
"dynamodb:Query",
"dynamodb:Scan"
],
"Resource": "arn:aws:dynamodb:us-west-2:account-id:table/Tools"
}
]
}
आप तीन उदाहरणों की समीक्षा कर सकते हैं जो इस प्रकार हैं -
Block the user from executing any table action.
{
"Version": "2016-05-23",
"Statement": [
{
"Sid": "AllAPIActionsOnTools",
"Effect": "Deny",
"Action": "dynamodb:*",
"Resource": "arn:aws:dynamodb:us-west-2:155556789012:table/Tools"
}
]
}
Block access to a table and its indices.
{
"Version": "2016-05-23",
"Statement": [
{
"Sid": "AccessAllIndexesOnTools",
"Effect": "Deny",
"Action": [
"dynamodb:*"
],
"Resource": [
"arn:aws:dynamodb:us-west-2:155556789012:table/Tools",
"arn:aws:dynamodb:us-west-2:155556789012:table/Tools/index/*"
]
}
]
}
Block a user from making a reserved capacity offering purchase.
{
"Version": "2016-05-23",
"Statement": [
{
"Sid": "BlockReservedCapacityPurchases",
"Effect": "Deny",
"Action": "dynamodb:PurchaseReservedCapacityOfferings",
"Resource": "arn:aws:dynamodb:us-west-2:155556789012:*"
}
]
}
अनुदान प्रदान करना: जीयूआई कंसोल का उपयोग करना
IAM नीतियां बनाने के लिए आप GUI कंसोल का भी उपयोग कर सकते हैं। के साथ शुरू करने के लिए, चुनेंTablesनेविगेशन फलक से। तालिका सूची में, लक्ष्य तालिका चुनें और इन चरणों का पालन करें।
Step 1 - का चयन करें Access control टैब।
Step 2- पहचान प्रदाता, कार्यों और नीति विशेषताओं का चयन करें। चुनते हैंCreate policy सभी सेटिंग्स दर्ज करने के बाद।
Step 3 - चुनें Attach policy instructions, और उचित IAM भूमिका के साथ पॉलिसी को जोड़ने के लिए प्रत्येक आवश्यक कदम को पूरा करें।
DynamoDB API एक बड़ा सेट प्रदान करता है, जिसमें अनुमतियों की आवश्यकता होती है। अनुमतियाँ सेट करने में, आपको अनुमत कार्यों, संसाधनों की अनुमति और प्रत्येक की शर्तों को स्थापित करना होगा।
आप पॉलिसी के एक्शन फ़ील्ड में कार्रवाई निर्दिष्ट कर सकते हैं। नीति के संसाधन क्षेत्र के भीतर संसाधन मूल्य निर्दिष्ट करें। लेकिन यह सुनिश्चित करें कि आप डायनामोड युक्त सही सिंटैक्स का उपयोग करें: एपीआई ऑपरेशन के साथ उपसर्ग।
उदाहरण के लिए - dynamodb:CreateTable
अनुमतियों को फ़िल्टर करने के लिए आप स्थिति कुंजियों को भी नियोजित कर सकते हैं।
अनुमतियाँ और एपीआई क्रियाएँ
निम्नलिखित क्रियाओं में दी गई एपीआई कार्रवाइयों और संबंधित अनुमतियों पर एक अच्छी नज़र डालें -
एपीआई ऑपरेशन | आवश्यक अनुमति |
---|---|
BatchGetItem | dynamodb: BatchGetItem |
BatchWriteItem | dynamodb: BatchWriteItem |
तालिका बनाएं | dynamodb: createTable |
चीज़ें हटाएं | dynamodb: DeleteItem |
DeleteTable | dynamodb: DeleteTable |
DescribeLimits | dynamodb: DescribeLimits |
DescribeReservedCapacity | dynamodb: DescribeReservedCapacity |
DescribeReservedCapacityOfferings | dynamodb: DescribeReservedCapacityOfferings |
DescribeStream | dynamodb: DescribeStream |
DescribeTable | dynamodb: DescribeTable |
वस्तु ले आओ | dynamodb: GetItem |
GetRecords | dynamodb: GetRecords |
GetShardIterator | dynamodb: GetShardIterator |
ListStreams | dynamodb: ListStreams |
ListTables | dynamodb: ListTables |
PurchaseReservedCapacityOfferings | dynamodb: PurchaseReservedCapacityOfferings |
PutItem | dynamodb: PutItem |
सवाल | dynamodb: क्वेरी |
स्कैन | dynamodb: स्कैन |
UpdateItem | dynamodb: UpdateItem |
UpdateTable | dynamodb: UpdateTable |
साधन
निम्नलिखित तालिका में, आप प्रत्येक अनुमत एपीआई कार्रवाई से जुड़े संसाधनों की समीक्षा कर सकते हैं -
एपीआई ऑपरेशन | संसाधन |
---|---|
BatchGetItem | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
BatchWriteItem | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
तालिका बनाएं | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
चीज़ें हटाएं | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
DeleteTable | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
DescribeLimits | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: * |
DescribeReservedCapacity | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: * |
DescribeReservedCapacityOfferings | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: * |
DescribeStream | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम / धारा / धारा-लेबल |
DescribeTable | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
वस्तु ले आओ | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
GetRecords | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम / धारा / धारा-लेबल |
GetShardIterator | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम / धारा / धारा-लेबल |
ListStreams | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम / धारा / * |
ListTables | * |
PurchaseReservedCapacityOfferings | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: * |
PutItem | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
सवाल | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम या अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम / सूचकांक / सूचकांक नाम |
स्कैन | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम या अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम / सूचकांक / सूचकांक नाम |
UpdateItem | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
UpdateTable | अर्न: एडब्ल्यूएस: dynamodb: क्षेत्र: खाता-आईडी: तालिका / टेबल नाम |
अनुमतियाँ प्रदान करने में, डायनामोडीबी उनके लिए शर्त कुंजी के साथ एक विस्तृत IAM नीति के माध्यम से शर्तों को निर्दिष्ट करने की अनुमति देता है। यह विशिष्ट वस्तुओं और विशेषताओं तक पहुंच जैसी सेटिंग्स का समर्थन करता है।
Note - डायनमोीडीबी किसी भी टैग का समर्थन नहीं करता है।
विस्तृत नियंत्रण
कई शर्तें आइटम और विशेषताओं के लिए विशिष्टता को नीचे ले जाने की अनुमति देती हैं, जैसे उपयोगकर्ता खाते के आधार पर विशिष्ट वस्तुओं को केवल पढ़ने के लिए एक्सेस देना। सशर्त IAM नीतियों के साथ इस स्तर के नियंत्रण को लागू करें, जो सुरक्षा क्रेडेंशियल्स का प्रबंधन करता है। फिर बस वांछित उपयोगकर्ताओं, समूहों और भूमिकाओं के लिए नीति लागू करें। वेब आइडेंटिटी फेडरेशन, जो एक विषय पर बाद में चर्चा करता है, अमेज़न, फेसबुक और Google लॉगिन के माध्यम से उपयोगकर्ता की पहुंच को नियंत्रित करने का एक तरीका भी प्रदान करता है।
IAM नीति का स्थिति तत्व अभिगम नियंत्रण को लागू करता है। आप बस इसे पॉलिसी में जोड़ते हैं। इसके उपयोग का एक उदाहरण टेबल आइटम और विशेषताओं तक पहुंच से इनकार करना या अनुमति देना शामिल है। अनुमतियों को सीमित करने के लिए शर्त तत्व शर्त कुंजियों को भी नियोजित कर सकता है।
आप स्थिति कुंजी के दो उदाहरणों की समीक्षा कर सकते हैं -
dynamodb:LeadingKeys - यह विभाजन कुंजी मूल्य से मेल खाता आईडी के बिना उपयोगकर्ताओं द्वारा आइटम एक्सेस को रोकता है।
dynamodb:Attributes - यह उपयोगकर्ताओं को सूचीबद्ध लोगों के बाहर विशेषताओं पर पहुंचने या संचालन करने से रोकता है।
मूल्यांकन पर, IAM नीतियों का परिणाम सही या गलत होता है। यदि कोई भी भाग गलत का मूल्यांकन करता है, तो पूरी नीति झूठी का मूल्यांकन करती है, जिसके परिणामस्वरूप पहुंच से वंचित किया जाता है। यह सुनिश्चित करने के लिए कि उपयोगकर्ता के पास उचित पहुँच हो, स्थिति कुंजियों में सभी आवश्यक जानकारी निर्दिष्ट करें।
पूर्वनिर्धारित स्थिति कुंजी
AWS पूर्वनिर्धारित स्थिति कुंजियों का एक संग्रह प्रदान करता है, जो सभी सेवाओं पर लागू होता है। वे उपयोगकर्ताओं और जांच की जांच में उपयोग और बारीक विवरण की एक विस्तृत श्रृंखला का समर्थन करते हैं।
Note - कंडीशन कीज़ में केस सेंसिटिविटी होती है।
आप निम्नलिखित सेवा-विशिष्ट कुंजी के चयन की समीक्षा कर सकते हैं -
dynamodb:LeadingKey- यह एक तालिका की पहली प्रमुख विशेषता का प्रतिनिधित्व करता है; विभाजन कुंजी। शर्तों में ForAllValues संशोधक का उपयोग करें।
dynamodb:Select- यह एक क्वेरी / स्कैन अनुरोध का चयन करता है पैरामीटर चुनें। इसका मान ALL_ATTRIBUTES, ALL_PROJECTED_ATTRIBUTES, SPECIFIC_ATTRIBUTES, या COUNT का होना चाहिए।
dynamodb:Attributes- यह एक अनुरोध के भीतर एक विशेषता नाम सूची का प्रतिनिधित्व करता है, या एक अनुरोध से लौटी विशेषताएँ। इसके मान और उनके कार्य एपीआई एक्शन पैरामीटर्स से मिलते-जुलते हैं, उदाहरण के लिए, बैचगेटेम एट्रिब्यूट्सटोजेट का उपयोग करता है।
dynamodb:ReturnValues - यह एक अनुरोध 'ReturnValues पैरामीटर का प्रतिनिधित्व करता है, और इन मूल्यों का उपयोग कर सकता है: ALL_OLD, UPDATED_OLD, ALL_NEW, UPDATED_NEW और NONE।
dynamodb:ReturnConsumedCapacity - यह अनुरोध के ReturnConsumedCapacity पैरामीटर का प्रतिनिधित्व करता है, और इन मूल्यों का उपयोग कर सकता है: TOTAL और NONE।
वेब आइडेंटिटी फेडरेशन आपको बड़े उपयोगकर्ता समूहों के लिए प्रमाणीकरण और प्राधिकरण को सरल बनाने की अनुमति देता है। आप व्यक्तिगत खातों के निर्माण को छोड़ सकते हैं, और अस्थायी क्रेडेंशियल या टोकन प्राप्त करने के लिए उपयोगकर्ताओं को पहचान प्रदाता में प्रवेश करने की आवश्यकता होती है। यह क्रेडेंशियल प्रबंधित करने के लिए AWS सुरक्षा टोकन सेवा (STS) का उपयोग करता है। एप्लिकेशन सेवाओं के साथ सहभागिता करने के लिए इन टोकन का उपयोग करते हैं।
वेब आइडेंटिटी फेडरेशन अन्य पहचान प्रदाताओं जैसे - अमेज़न, गूगल और फेसबुक का भी समर्थन करता है।
Function- उपयोग में, वेब आइडेंटिटी फेडरेशन पहले उपयोगकर्ता और ऐप प्रमाणीकरण के लिए एक पहचान प्रदाता को कॉल करता है, और प्रदाता एक टोकन लौटाता है। इसका परिणाम ऐप में AWS STS को कॉल करना और इनपुट के लिए टोकन पास करना है। एसटीएस ऐप को अधिकृत करता है और इसे अस्थायी एक्सेस क्रेडेंशियल्स देता है, जो ऐप को नीति पर आधारित IAM भूमिका और एक्सेस संसाधनों का उपयोग करने की अनुमति देता है।
वेब आइडेंटिटी फेडरेशन को लागू करना
उपयोग करने से पहले आपको निम्नलिखित तीन चरण करने होंगे -
डेवलपर के रूप में पंजीकरण करने के लिए एक समर्थित तृतीय पक्ष पहचान प्रदाता का उपयोग करें।
ऐप आईडी प्राप्त करने के लिए प्रदाता के साथ अपना आवेदन पंजीकृत करें।
पॉलिसी अनुलग्नक सहित एकल या एकाधिक IAM भूमिकाएँ बनाएं। आपको प्रति ऐप प्रति प्रदाता एक भूमिका का उपयोग करना चाहिए।
वेब पहचान फेडरेशन का उपयोग करने के लिए अपनी IAM भूमिकाओं में से एक मान लें। आपके ऐप को तब तीन-चरण की प्रक्रिया करनी होगी -
- Authentication
- क्रेडेंशियल अधिग्रहण
- संसाधन का उपयोग
पहले चरण में, आपका ऐप प्रदाता को कॉल करने के लिए अपने स्वयं के इंटरफ़ेस का उपयोग करता है और फिर टोकन प्रक्रिया का प्रबंधन करता है।
फिर चरण दो टोकन का प्रबंधन करें और अपने ऐप को एक भेजने की आवश्यकता है AssumeRoleWithWebIdentityAWS STS से अनुरोध। अनुरोध में पहले टोकन, प्रदाता ऐप आईडी और IAM भूमिका का ARN होता है। एसटीएस एक निश्चित अवधि के बाद समाप्त करने के लिए सेट क्रेडेंशियल प्रदान करता है।
अंतिम चरण में, आपके एप्लिकेशन को STS से एक प्रतिक्रिया प्राप्त होती है जिसमें DynamoDB संसाधनों की एक्सेस जानकारी होती है। इसमें एक्सेस क्रेडेंशियल्स, समाप्ति समय, भूमिका और भूमिका आईडी शामिल हैं।
डेटा पाइपलाइन किसी तालिका, फ़ाइल, या S3 बाल्टी से / के लिए डेटा निर्यात और आयात करने की अनुमति देता है। यह पाठ्यक्रम बैकअप, परीक्षण और समान आवश्यकताओं या परिदृश्यों के लिए उपयोगी साबित होता है।
एक निर्यात में, आप डेटा पाइपलाइन कंसोल का उपयोग करते हैं, जो एक नई पाइपलाइन बनाता है और निर्यात करने के लिए अमेज़ॅन ईएमआर (इलास्टिक मैपरेड) क्लस्टर लॉन्च करता है। एक EMR DynamoDB से डेटा पढ़ता है और लक्ष्य को लिखता है। हम इस ट्यूटोरियल में बाद में EMR पर विस्तार से चर्चा करते हैं।
एक आयात ऑपरेशन में, आप डेटा पाइपलाइन कंसोल का उपयोग करते हैं, जो एक पाइपलाइन बनाता है और आयात करने के लिए EMR लॉन्च करता है। यह स्रोत से डेटा पढ़ता है और गंतव्य को लिखता है।
Note - एक्सपोर्ट / इम्पोर्ट ऑपरेशंस में इस्तेमाल की गई सेवाओं, विशेषकर ईएमआर और एस 3 को देखते हुए लागत वहन करते हैं।
डेटा पाइपलाइन का उपयोग करना
डेटा पाइपलाइन का उपयोग करते समय आपको कार्रवाई और संसाधन अनुमतियाँ निर्दिष्ट करनी चाहिए। आप उन्हें परिभाषित करने के लिए IAM भूमिका या नीति का उपयोग कर सकते हैं। जो उपयोगकर्ता आयात / निर्यात कर रहे हैं, उन्हें एक नोट करना चाहिए कि उन्हें एक सक्रिय एक्सेस कुंजी आईडी और गुप्त कुंजी की आवश्यकता होगी।
डेटा पाइपलाइन के लिए IAM रोल्स
डेटा पाइपलाइन का उपयोग करने के लिए आपको दो IAM भूमिकाओं की आवश्यकता है -
DataPipelineDefaultRole - इसमें वे सभी क्रियाएं हैं जो आप पाइपलाइन को आपके लिए प्रदर्शन करने की अनुमति देते हैं।
DataPipelineDefaultResourceRole - इसके पास संसाधन हैं जो आप पाइपलाइन को आपके लिए प्रावधान करने की अनुमति देते हैं।
यदि आप डेटा पाइपलाइन के लिए नए हैं, तो आपको प्रत्येक भूमिका को स्पॉन करना होगा। पिछले सभी उपयोगकर्ता मौजूदा भूमिकाओं के कारण इन भूमिकाओं के अधिकारी हैं।
डेटा पाइपलाइन के लिए IAM भूमिकाएँ बनाने के लिए IAM कंसोल का उपयोग करें, और निम्न चार चरण करें -
Step 1 - IAM कंसोल पर स्थित में लॉग इन करें https://console.aws.amazon.com/iam/
Step 2 - चयन करें Roles डैशबोर्ड से।
Step 3 - चयन करें Create New Role। इसके बाद DataPipelineDefaultRole डालेंRole Name क्षेत्र, और चयन करें Next Step। मेंAWS Service Roles में सूची Role Type पैनल, नेविगेट करने के लिए Data Pipeline, और चुनें Select। चुनते हैंCreate Role में Review पैनल।
Step 4 - चयन करें Create New Role।
बैकअप करने के लिए डेटा पाइपलाइन के आयात / निर्यात कार्यक्षमता का उपयोग करें। आप किसी बैकअप को कैसे निष्पादित करते हैं, यह इस पर निर्भर करता है कि आप GUI कंसोल का उपयोग करते हैं, या सीधे डेटा (API) का उपयोग करते हैं। कंसोल का उपयोग करते समय या तो प्रत्येक तालिका के लिए अलग-अलग पाइपलाइन बनाएं, या एक सीधे विकल्प का उपयोग करते हुए एक ही पाइपलाइन में कई तालिकाओं को आयात / निर्यात करें।
डेटा का निर्यात और आयात करना
निर्यात करने से पहले आपको अमेजन S3 बाल्टी बनाना होगा। आप एक या अधिक तालिकाओं से निर्यात कर सकते हैं।
निर्यात निष्पादित करने के लिए निम्नलिखित चार चरण प्रक्रिया करें -
Step 1 - AWS मैनेजमेंट कंसोल में लॉग इन करें और यहां स्थित डाटा पाइपलाइन कंसोल को खोलें https://console.aws.amazon.com/datapipeline/
Step 2 - यदि आपके पास उपयोग किए गए AWS क्षेत्र में कोई पाइपलाइन नहीं है, तो चयन करें Get started now। यदि आपके पास एक या अधिक है, तो चयन करेंCreate new pipeline।
Step 3- निर्माण पृष्ठ पर, अपनी पाइपलाइन के लिए एक नाम दर्ज करें। चुनेंBuild using a templateस्रोत पैरामीटर के लिए। चुनते हैंExport DynamoDB table to S3सूची से। में स्रोत तालिका दर्ज करेंSource DynamoDB table name मैदान।
गंतव्य S3 बाल्टी में प्रवेश करें Output S3 Folderनिम्नलिखित प्रारूप का उपयोग करके टेक्स्ट बॉक्स: s3: // nameOfBucket / क्षेत्र / nameOfFolder। लॉग फ़ाइल के लिए एक S3 गंतव्य दर्ज करेंS3 location for logs पाठ बॉक्स।
Step 4 - चयन करें Activate सभी सेटिंग्स दर्ज करने के बाद।
इसकी निर्माण प्रक्रिया को पूरा करने में पाइपलाइन को कई मिनट लग सकते हैं। इसकी स्थिति की निगरानी के लिए कंसोल का उपयोग करें। निर्यात की गई फ़ाइल को देखकर S3 कंसोल के साथ सफल प्रसंस्करण की पुष्टि करें।
डेटा आयात करना
सफल आयात केवल तभी हो सकता है यदि निम्न स्थितियां सत्य हैं: आपने एक गंतव्य तालिका बनाई है, गंतव्य और स्रोत समान नामों का उपयोग करते हैं, और गंतव्य और स्रोत समान कुंजी स्कीमा का उपयोग करते हैं।
आप एक पॉप्युलेटेड डेस्टिनेशन टेबल का उपयोग कर सकते हैं, हालाँकि, सोर्स आइटम्स के साथ एक कुंजी साझा करने वाले डेटा आइटम्स को इम्पोर्ट करते हैं, और टेबल पर अतिरिक्त आइटम भी जोड़ते हैं। गंतव्य एक अलग क्षेत्र का भी उपयोग कर सकता है।
यद्यपि आप कई स्रोतों का निर्यात कर सकते हैं, आप केवल प्रति ऑपरेशन एक आयात कर सकते हैं। आप निम्नलिखित चरणों का पालन करके एक आयात कर सकते हैं -
Step 1 - एडब्ल्यूएस प्रबंधन कंसोल में लॉग इन करें, और फिर डेटा पाइपलाइन कंसोल खोलें।
Step 2 - यदि आप एक क्रॉस क्षेत्र आयात को निष्पादित करने का इरादा कर रहे हैं, तो आपको गंतव्य क्षेत्र का चयन करना चाहिए।
Step 3 - चयन करें Create new pipeline।
Step 4 - में पाइपलाइन नाम दर्ज करें Nameमैदान। चुनेंBuild using a template स्रोत पैरामीटर के लिए, और टेम्पलेट सूची में, का चयन करें Import DynamoDB backup data from S3।
में स्रोत फ़ाइल का स्थान दर्ज करें Input S3 Folderपाठ बॉक्स। में गंतव्य तालिका नाम दर्ज करेंTarget DynamoDB table nameमैदान। फिर लॉग फ़ाइल के लिए स्थान दर्ज करेंS3 location for logs पाठ बॉक्स।
Step 5 - चयन करें Activate सभी सेटिंग्स दर्ज करने के बाद।
आयात पाइपलाइन निर्माण के तुरंत बाद शुरू होता है। निर्माण प्रक्रिया को पूरा करने में पाइपलाइन के लिए कई मिनट लग सकते हैं।
त्रुटियाँ
जब त्रुटियां होती हैं, तो डेटा पाइपलाइन कंसोल ERROR को पाइपलाइन स्थिति के रूप में प्रदर्शित करता है। एक त्रुटि के साथ पाइपलाइन पर क्लिक करना आपको इसके विस्तार पृष्ठ पर ले जाता है, जो प्रक्रिया के हर चरण और उस बिंदु को प्रकट करता है जिस पर विफलता हुई। लॉग फ़ाइलों में भी कुछ अंतर्दृष्टि प्रदान करते हैं।
आप त्रुटियों के सामान्य कारणों की समीक्षा कर सकते हैं -
किसी आयात के लिए गंतव्य तालिका मौजूद नहीं है, या स्रोत के लिए समान कुंजी स्कीमा का उपयोग नहीं करता है।
S3 बाल्टी मौजूद नहीं है, या आपके पास इसके लिए पढ़ने / लिखने की अनुमति नहीं है।
पाइप लाइन का समय समाप्त हो गया।
आपके पास आवश्यक निर्यात / आयात अनुमतियाँ नहीं हैं।
आपका AWS खाता अपनी संसाधन सीमा तक पहुँच गया है।
Amazon CloudWatch कंसोल, कमांड लाइन या CloudWatch API के माध्यम से प्रदर्शन को एकत्र करने और विश्लेषण करने के लिए CloudWatch प्रदान करता है। आप इसका उपयोग अलार्म सेट करने और कार्य करने के लिए भी कर सकते हैं। यह कुछ घटनाओं पर निर्दिष्ट कार्य करता है।
क्लाउडवॉच कंसोल
प्रबंधन कंसोल पर पहुँच कर, और फिर CloudWatch कंसोल को खोलकर CloudWatch का उपयोग करें https://console.aws.amazon.com/cloudwatch/।
फिर आप निम्न चरणों का पालन कर सकते हैं -
चुनते हैं Metrics नेविगेशन फलक से।
डायनेमोडी मेट्रिक्स के तहत CloudWatch Metrics by Category फलक, चुनें Table Metrics।
नीचे स्क्रॉल करने के लिए ऊपरी फलक का उपयोग करें और तालिका मैट्रिक्स की पूरी सूची की जांच करें। Viewing सूची मैट्रिक्स विकल्प प्रदान करती है।
परिणाम इंटरफ़ेस में, आप संसाधन नाम और मीट्रिक के पास स्थित चेकबॉक्स का चयन करके प्रत्येक मीट्रिक का चयन / चयन रद्द कर सकते हैं। तब आप प्रत्येक आइटम के लिए रेखांकन देख पाएंगे।
एपीआई एकीकरण
आप क्लाउड क्वच को क्वेरी से एक्सेस कर सकते हैं। CloudWatch क्रिया करने के लिए मीट्रिक मानों का उपयोग करें। नोट डायनेमोबीडी शून्य के मान के साथ मैट्रिक्स नहीं भेजता है। यह केवल समय अवधि के लिए मैट्रिक्स को छोड़ देता है जहां उन मैट्रिक्स उस मूल्य पर बने रहते हैं।
निम्नलिखित कुछ सबसे अधिक उपयोग की जाने वाली मीट्रिक हैं -
ConditionalCheckFailedRequests- यह सशर्त प्रयासों की मात्रा को ट्रैक करता है जैसे सशर्त पुटिमम लिखते हैं। असफल इस मिथक को बढ़ा-चढ़ाकर लिखता है। यह भी एक HTTP 400 त्रुटि फेंकता है।
ConsumedReadCapacityUnits- यह एक निश्चित समय अवधि में उपयोग की जाने वाली क्षमता इकाइयों को निर्धारित करता है। आप इसका उपयोग व्यक्तिगत तालिका और सूचकांक खपत की जांच करने के लिए कर सकते हैं।
ConsumedWriteCapacityUnits- यह एक निश्चित समय अवधि में उपयोग की जाने वाली क्षमता इकाइयों को निर्धारित करता है। आप इसका उपयोग व्यक्तिगत तालिका और सूचकांक खपत की जांच करने के लिए कर सकते हैं।
ReadThrottleEvents- यह टेबल / इंडेक्स रीड्स में प्रावधानित क्षमता इकाइयों से अधिक के अनुरोधों को निर्धारित करता है। यह प्रत्येक थ्रोटल पर कई थ्रॉटल के साथ बैच संचालन सहित वेतन वृद्धि करता है।
ReturnedBytes - यह एक निश्चित समय अवधि के भीतर पुनर्प्राप्ति कार्यों में लौटे बाइट्स को निर्धारित करता है।
ReturnedItemCount- यह एक निश्चित समयावधि में क्वेरी और स्कैन परिचालनों में लौटाए गए आइटमों की मात्रा निर्धारित करता है। यह केवल उन वस्तुओं को संबोधित करता है, जिनका मूल्यांकन नहीं किया गया है, जो आमतौर पर पूरी तरह से अलग आंकड़े हैं।
Note - ऐसे कई और मैट्रिक्स हैं जो मौजूद हैं, और इनमें से अधिकांश आपको औसत, रकम, अधिकतम, न्यूनतम और गणना की गणना करने की अनुमति देते हैं।
डायनेमोडी में क्लाउडट्रेड इंटीग्रेशन शामिल है। यह एक खाते में डायनेमोबीडी से या के लिए निम्न-स्तरीय एपीआई अनुरोधों को कैप्चर करता है, और एक निर्दिष्ट S3 बाल्टी में लॉग फाइल भेजता है। यह कंसोल या एपीआई से कॉल को लक्षित करता है। आप इस डेटा का उपयोग किए गए अनुरोधों और उनके स्रोत, उपयोगकर्ता, टाइमस्टैम्प और बहुत कुछ निर्धारित करने के लिए कर सकते हैं।
सक्षम होने पर, यह लॉग फ़ाइलों में क्रियाओं को ट्रैक करता है, जिसमें अन्य सेवा रिकॉर्ड शामिल हैं। यह आठ क्रियाओं और दो धाराओं का समर्थन करता है -
आठ क्रियाएं इस प्रकार हैं -
- CreateTable
- DeleteTable
- DescribeTable
- ListTables
- UpdateTable
- DescribeReservedCapacity
- DescribeReservedCapacityOfferings
- PurchaseReservedCapacityOfferings
जबकि, दो धाराएँ हैं -
- DescribeStream
- ListStreams
सभी लॉग में अनुरोध करने वाले खातों के बारे में जानकारी होती है। आप विस्तृत जानकारी निर्धारित कर सकते हैं जैसे रूट या IAM उपयोगकर्ताओं ने अनुरोध किया था, या अस्थायी क्रेडेंशियल या फ़ेडरेटेड के साथ।
लॉग फ़ाइलें भंडारण और हटाने के लिए सेटिंग्स के साथ, हालांकि आप लंबे समय तक निर्दिष्ट करते हैं। डिफ़ॉल्ट एन्क्रिप्टेड लॉग बनाता है। आप नए लॉग के लिए अलर्ट सेट कर सकते हैं। आप एक ही बाल्टी में कई लॉग, क्षेत्रों और खातों में भी व्यवस्थित कर सकते हैं।
लॉग फ़ाइलों की व्याख्या
प्रत्येक फ़ाइल में एक या एक से अधिक प्रविष्टियाँ होती हैं। प्रत्येक प्रविष्टि में कई JSON प्रारूप ईवेंट होते हैं। एक प्रविष्टि एक अनुरोध का प्रतिनिधित्व करती है, और इसमें संबंधित जानकारी शामिल होती है; आदेश की कोई गारंटी नहीं है।
आप निम्न नमूना लॉग फ़ाइल की समीक्षा कर सकते हैं -
{"Records": [
{
"eventVersion": "5.05",
"userIdentity": {
"type": "AssumedRole",
"principalId": "AKTTIOSZODNN8SAMPLE:jane",
"arn": "arn:aws:sts::155522255533:assumed-role/users/jane",
"accountId": "155522255533",
"accessKeyId": "AKTTIOSZODNN8SAMPLE",
"sessionContext": {
"attributes": {
"mfaAuthenticated": "false",
"creationDate": "2016-05-11T19:01:01Z"
},
"sessionIssuer": {
"type": "Role",
"principalId": "AKTTI44ZZ6DHBSAMPLE",
"arn": "arn:aws:iam::499955777666:role/admin-role",
"accountId": "499955777666",
"userName": "jill"
}
}
},
"eventTime": "2016-05-11T14:33:20Z",
"eventSource": "dynamodb.amazonaws.com",
"eventName": "DeleteTable",
"awsRegion": "us-west-2",
"sourceIPAddress": "192.0.2.0",
"userAgent": "console.aws.amazon.com",
"requestParameters": {"tableName": "Tools"},
"responseElements": {"tableDescription": {
"tableName": "Tools",
"itemCount": 0,
"provisionedThroughput": {
"writeCapacityUnits": 25,
"numberOfDecreasesToday": 0,
"readCapacityUnits": 25
},
"tableStatus": "DELETING",
"tableSizeBytes": 0
}},
"requestID": "4D89G7D98GF7G8A7DF78FG89AS7GFSO5AEMVJF66Q9ASUAAJG",
"eventID": "a954451c-c2fc-4561-8aea-7a30ba1fdf52",
"eventType": "AwsApiCall",
"apiVersion": "2013-04-22",
"recipientAccountId": "155522255533"
}
]}
अमेज़ॅन का इलास्टिक मैपड्राइड (EMR) आपको बड़े डेटा को जल्दी और कुशलता से संसाधित करने की अनुमति देता है। EMR EC2 उदाहरणों पर Apache Hadoop चलाता है, लेकिन प्रक्रिया को सरल करता है। आप Apache Hive से क्वेरी मैप को कम करते हुए HiveQL के माध्यम से जॉब फ्लो का उपयोग करते हैं , एक क्वेरी भाषा जो एसक्यूएल जैसी है। अपाचे हाइव प्रश्नों और आपके अनुप्रयोगों को अनुकूलित करने का एक तरीका है।
आप नौकरी के प्रवाह को लॉन्च करने के लिए प्रबंधन कंसोल, ईएमआर सीएलआई, एक एपीआई या एसडीके के ईएमआर टैब का उपयोग कर सकते हैं। आपके पास हाइव को अंतःक्रियात्मक रूप से चलाने या स्क्रिप्ट का उपयोग करने का विकल्प भी है।
EMR पढ़ने / लिखने के संचालन से थ्रूपुट की खपत पर असर पड़ता है, हालांकि, बड़े अनुरोधों में, यह बैकऑफ़ एल्गोरिथ्म के संरक्षण के साथ रिट्रीट करता है। इसके अलावा, अन्य कार्यों और कार्यों के साथ ईएमआर समवर्ती चलाने से थ्रॉटलिंग हो सकता है।
DynamoDB / EMR एकीकरण बाइनरी और बाइनरी सेट विशेषताओं का समर्थन नहीं करता है।
डायनमोडीबी / ईएमआर एकीकरण पूर्वापेक्षाएँ
EMR का उपयोग करने से पहले आवश्यक वस्तुओं की इस चेकलिस्ट की समीक्षा करें -
- एक एडब्ल्यूएस खाता
- EMR परिचालनों में नियोजित एक ही खाते के तहत एक आबादी वाली तालिका
- डायनमोडीबी कनेक्टिविटी के साथ एक कस्टम हाइव संस्करण
- डायनेमोडीबी कनेक्टिविटी सपोर्ट
- एक S3 बाल्टी (वैकल्पिक)
- एक SSH ग्राहक (वैकल्पिक)
- EC2 कुंजी जोड़ी (वैकल्पिक)
हाइव सेटअप
ईएमआर का उपयोग करने से पहले, हाइव को इंटरैक्टिव मोड में चलाने के लिए एक महत्वपूर्ण जोड़ी बनाएं। प्रमुख जोड़ी ईसी 2 इंस्टेंस के कनेक्शन और नौकरी के प्रवाह के मास्टर नोड्स की अनुमति देती है।
आप बाद के चरणों का पालन करके यह प्रदर्शन कर सकते हैं -
प्रबंधन कंसोल में लॉग इन करें, और EC2 कंसोल पर स्थित खोलें https://console.aws.amazon.com/ec2/
कंसोल के ऊपरी, दाएँ हाथ के भाग में एक क्षेत्र का चयन करें। सुनिश्चित करें कि क्षेत्र डायनमोडीबी क्षेत्र से मेल खाता है।
नेविगेशन फलक में, का चयन करें Key Pairs।
चुनते हैं Create Key Pair।
में Key Pair Name फ़ील्ड, एक नाम दर्ज करें और चुनें Create।
परिणामी निजी कुंजी फ़ाइल डाउनलोड करें जो निम्न प्रारूप का उपयोग करती है: filename.pem।
Note - आप प्रमुख जोड़ी के बिना EC2 उदाहरणों से कनेक्ट नहीं कर सकते।
हाइव क्लस्टर
हाइव चलाने के लिए हाइव-इनेबल्ड क्लस्टर बनाएं। यह Hive-to-DynamoDB कनेक्शन के लिए अनुप्रयोगों और बुनियादी ढांचे के आवश्यक वातावरण का निर्माण करता है।
आप निम्न चरणों का उपयोग करके इस कार्य को कर सकते हैं -
EMR कंसोल पर पहुँचें।
चुनते हैं Create Cluster।
निर्माण स्क्रीन में, क्लस्टर के लिए एक वर्णनात्मक नाम के साथ क्लस्टर कॉन्फ़िगरेशन सेट करें, चुनें Yes समाप्ति सुरक्षा और जाँच के लिए Enabled लॉगिंग के लिए, एक S3 गंतव्य के लिए log folder S3 location, तथा Enabled डिबगिंग के लिए।
सॉफ़्टवेयर कॉन्फ़िगरेशन स्क्रीन में, फ़ील्ड होल्ड करना सुनिश्चित करें Amazon Hadoop वितरण के लिए, एएमआई संस्करण के लिए नवीनतम संस्करण, इंस्टाल-हाइव के लिए एप्लिकेशन के लिए एक डिफ़ॉल्ट हाइव संस्करण और इंस्टाल-पिग के लिए एप्लिकेशन के लिए एक डिफ़ॉल्ट पिग संस्करण है।
हार्डवेयर कॉन्फ़िगरेशन स्क्रीन में, फ़ील्ड सुनिश्चित करें Launch into EC2-Classic नेटवर्क के लिए, No Preference EC2 उपलब्धता क्षेत्र के लिए, मास्टर-अमेज़ॅन EC2 इंस्टेंस प्रकार के लिए डिफ़ॉल्ट, अनुरोध स्पॉट इंस्टेंसेस के लिए कोई चेक नहीं, कोर-अमेज़ॅन EC2 इंस्टेंस प्रकार के लिए डिफ़ॉल्ट 2 काउंट के लिए, रिक्वेस्ट स्पॉट इंस्टेंस के लिए कोई चेक नहीं, टास्क-अमेज़ॅन EC2 इंस्टेंस टाइप के लिए डिफ़ॉल्ट, 0 काउंट के लिए, और रिक्वेस्ट स्पॉट इंस्टेंस के लिए कोई चेक नहीं।
क्लस्टर विफलता को रोकने के लिए पर्याप्त क्षमता प्रदान करने वाली सीमा निर्धारित करना सुनिश्चित करें।
सुरक्षा और पहुँच स्क्रीन में, सुनिश्चित करें कि फ़ील्ड EC2 कुंजी जोड़ी में आपकी मुख्य जोड़ी रखती हैं, No other IAM users IAM उपयोगकर्ता पहुंच में, और Proceed without roles IAM भूमिका में।
बूटस्ट्रैप एक्शन स्क्रीन की समीक्षा करें, लेकिन इसे संशोधित न करें।
सेटिंग्स की समीक्षा करें, और चुनें Create Cluster जब समाप्त हो जाए।
ए Summary क्लस्टर की शुरुआत में फलक दिखाई देता है।
SSH सत्र को सक्रिय करें
मास्टर नोड से कनेक्ट करने और सीएलआई संचालन निष्पादित करने के लिए आपको एक सक्रिय एसएसएच सत्र की आवश्यकता है। EMR कंसोल में क्लस्टर का चयन करके मास्टर नोड का पता लगाएँ। यह मास्टर नोड को सूचीबद्ध करता हैMaster Public DNS Name।
यदि आपके पास नहीं है तो PuTTY स्थापित करें। इसके बाद PuTTYgen लॉन्च करें और चुनेंLoad। अपनी PEM फ़ाइल चुनें, और इसे खोलें। PuTTYgen आपको सफल आयात की सूचना देगा। चुनते हैंSave private key PuTTY निजी कुंजी प्रारूप (PPK) में बचाने के लिए, और चुनें Yesपास वाक्यांश के बिना बचत के लिए। फिर पुटी कुंजी के लिए एक नाम दर्ज करें, हिट करेंSave, और PuTTYgen को बंद करें।
पहले शुरू करने के लिए मास्टर नोड के साथ संबंध बनाने के लिए PuTTY का उपयोग करें। चुनेंSessionश्रेणी सूची से होस्ट नाम फ़ील्ड के भीतर hasoop @ DNS दर्ज करें। विस्तारConnection > SSH श्रेणी सूची में, और चुनें Auth। नियंत्रण विकल्प स्क्रीन में, का चयन करेंBrowseप्रमाणीकरण के लिए निजी कुंजी फ़ाइल के लिए। फिर अपनी निजी कुंजी फ़ाइल चुनें और इसे खोलें। चुनते हैंYes सुरक्षा चेतावनी पॉप-अप के लिए।
जब मास्टर नोड से जुड़ा होता है, तो एक Hadoop कमांड प्रॉम्प्ट दिखाई देता है, जिसका अर्थ है कि आप एक इंटरैक्टिव हाइव सत्र शुरू कर सकते हैं।
छत्ता तालिका
Hive एक डेटा वेयरहाउस टूल के रूप में कार्य करता है जो HiveQL का उपयोग करते हुए EMR क्लस्टर्स पर प्रश्नों की अनुमति देता है । पिछले सेटअप आपको काम करने का संकेत देते हैं। केवल "हाइव" दर्ज करके और फिर आपकी इच्छा के अनुसार किसी भी आदेश को दर्ज करके हाइव कमांड को अंतःक्रियात्मक रूप से चलाएं। के बारे में अधिक जानकारी के लिए हमारी हाइव ट्यूटोरियल देखें हाइव ।
DynamoDB स्ट्रीम आपको टेबल आइटम परिवर्तनों पर नज़र रखने और प्रतिक्रिया करने में सक्षम बनाती हैं। एक एप्लिकेशन बनाने के लिए इस कार्यक्षमता पर काम करें जो स्रोतों में जानकारी को अपडेट करके परिवर्तनों का जवाब देती है। एक बड़े, बहु-उपयोगकर्ता प्रणाली के हजारों उपयोगकर्ताओं के लिए डेटा सिंक्रनाइज़ करें। अपडेट पर उपयोगकर्ताओं को सूचनाएं भेजने के लिए इसका उपयोग करें। इसके अनुप्रयोग विविध और पर्याप्त साबित होते हैं। डायनामोबीडी धारा इस कार्यक्षमता को प्राप्त करने के लिए मुख्य उपकरण के रूप में काम करती है।
धाराएँ तालिका के भीतर आइटम संशोधनों वाले समय-क्रम वाले अनुक्रमों को पकड़ती हैं। वे अधिकतम 24 घंटे के लिए इस डेटा को रखते हैं। एप्लिकेशन उन्हें वास्तविक समय में लगभग मूल और संशोधित आइटम देखने के लिए उपयोग करते हैं।
तालिका में सक्षम स्ट्रीम सभी संशोधनों को कैप्चर करती हैं। किसी भी CRUD ऑपरेशन पर, डायनेमोडीबी संशोधित वस्तुओं की प्राथमिक प्रमुख विशेषताओं के साथ एक स्ट्रीम रिकॉर्ड बनाता है। आप पहले और बाद की छवियों जैसे अतिरिक्त जानकारी के लिए स्ट्रीम कॉन्फ़िगर कर सकते हैं।
धाराएं दो गारंटी लेती हैं -
प्रत्येक रिकॉर्ड स्ट्रीम में एक बार दिखाई देता है और
प्रत्येक आइटम संशोधन संशोधनों के समान क्रम के स्ट्रीम रिकॉर्ड में परिणाम करता है।
सभी स्ट्रीम वास्तविक समय में प्रक्रिया करते हैं ताकि आप उन्हें अनुप्रयोगों में संबंधित कार्यक्षमता के लिए नियोजित कर सकें।
धाराओं का प्रबंधन
टेबल निर्माण पर, आप एक स्ट्रीम को सक्षम कर सकते हैं। मौजूदा तालिकाएँ स्ट्रीम को अक्षम करने या सेटिंग बदलने की अनुमति देती हैं। धाराएँ अतुल्यकालिक ऑपरेशन की सुविधा प्रदान करती हैं, जिसका अर्थ है तालिका प्रदर्शन प्रभाव नहीं।
सरल धारा प्रबंधन के लिए AWS प्रबंधन कंसोल का उपयोग करें। सबसे पहले, कंसोल पर नेविगेट करें, और चुनेंTables। अवलोकन टैब में, चुनेंManage Stream। विंडो के अंदर, टेबल डेटा संशोधनों पर एक स्ट्रीम में जोड़ी गई जानकारी का चयन करें। सभी सेटिंग्स दर्ज करने के बाद, चयन करेंEnable।
यदि आप किसी भी मौजूदा स्ट्रीम को अक्षम करना चाहते हैं, तो चुनें Manage Stream, और फिर Disable।
किसी स्ट्रीम को सक्षम या परिवर्तित करने के लिए आप APIs CreateTable और UpdateTable का भी उपयोग कर सकते हैं। स्ट्रीम को कॉन्फ़िगर करने के लिए पैरामीटर StreamSpecification का उपयोग करें। StreamEnabled स्थिति निर्दिष्ट करता है, जिसका अर्थ है सक्षम के लिए सत्य और अक्षम के लिए असत्य।
StreamViewType स्ट्रीम में जोड़ी गई जानकारी को निर्दिष्ट करता है: KEYS_ONLY, NEW_IMAGE, OLD_IMAGE और NEW_AND_OLD_IMAGES।
स्ट्रीम पढ़ना
एक समापन बिंदु से कनेक्ट करके और एपीआई अनुरोध बनाकर स्ट्रीम पढ़ें और प्रक्रिया करें। प्रत्येक स्ट्रीम में स्ट्रीम रिकॉर्ड होते हैं, और प्रत्येक रिकॉर्ड एकल संशोधन के रूप में मौजूद होता है जो स्ट्रीम का मालिक होता है। स्ट्रीम रिकॉर्ड में प्रकाशन क्रम का एक क्रम संख्या शामिल है। अभिलेख समूहों से संबंधित हैं जिन्हें शार्क के रूप में भी जाना जाता है। कई रिकॉर्ड के लिए कंटेनर के रूप में कार्य करता है, और रिकॉर्ड तक पहुंचने और ट्रैवर्स करने के लिए आवश्यक जानकारी भी रखता है। 24 घंटों के बाद, रिकॉर्ड स्वचालित रूप से हटा देते हैं।
ये Shards आवश्यकतानुसार उत्पन्न और हटाए जाते हैं, और लंबे समय तक नहीं रहते हैं। वे स्वचालित रूप से कई नए शार्क में विभाजित होते हैं, आमतौर पर गतिविधि स्पाइक लिखने के लिए। स्ट्रीम डिसएबल करने पर, ओपन शार्ड्स करीब। शार्क के बीच पदानुक्रमित संबंध का मतलब है कि अनुप्रयोगों को सही प्रसंस्करण क्रम के लिए माता-पिता की शार्क को प्राथमिकता देनी चाहिए। स्वचालित रूप से ऐसा करने के लिए आप Kinesis Adapter का उपयोग कर सकते हैं।
Note - बिना किसी बदलाव के किए गए ऑपरेशन स्ट्रीम रिकॉर्ड नहीं लिखते हैं।
एक्सेस और प्रोसेसिंग रिकॉर्ड के लिए निम्नलिखित कार्य करने की आवश्यकता होती है -
- लक्ष्य स्ट्रीम के ARN को निर्धारित करें।
- लक्ष्य रिकॉर्ड रखने वाली धारा के शार्ड (एस) को निर्धारित करें।
- वांछित रिकॉर्ड्स को पुनः प्राप्त करने के लिए शार्क (एस) पर पहुँचें।
Note- एक बार में एक शार्क पढ़ने की अधिकतम 2 प्रक्रियाएं होनी चाहिए। यदि यह 2 प्रक्रियाओं से अधिक है, तो यह स्रोत को कुचलना कर सकता है।
उपलब्ध स्ट्रीम कार्रवाई में शामिल हैं
- ListStreams
- DescribeStream
- GetShardIterator
- GetRecords
आप स्ट्रीम पढ़ने के निम्नलिखित उदाहरण की समीक्षा कर सकते हैं -
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBStreamsClient;
import com.amazonaws.services.dynamodbv2.model.AttributeAction;
import com.amazonaws.services.dynamodbv2.model.AttributeDefinition;
import com.amazonaws.services.dynamodbv2.model.AttributeValue;
import com.amazonaws.services.dynamodbv2.model.AttributeValueUpdate;
import com.amazonaws.services.dynamodbv2.model.CreateTableRequest;
import com.amazonaws.services.dynamodbv2.model.DescribeStreamRequest;
import com.amazonaws.services.dynamodbv2.model.DescribeStreamResult;
import com.amazonaws.services.dynamodbv2.model.DescribeTableResult;
import com.amazonaws.services.dynamodbv2.model.GetRecordsRequest;
import com.amazonaws.services.dynamodbv2.model.GetRecordsResult;
import com.amazonaws.services.dynamodbv2.model.GetShardIteratorRequest;
import com.amazonaws.services.dynamodbv2.model.GetShardIteratorResult;
import com.amazonaws.services.dynamodbv2.model.KeySchemaElement;
import com.amazonaws.services.dynamodbv2.model.KeyType;
import com.amazonaws.services.dynamodbv2.model.ProvisionedThroughput;
import com.amazonaws.services.dynamodbv2.model.Record;
import com.amazonaws.services.dynamodbv2.model.Shard;
import com.amazonaws.services.dynamodbv2.model.ShardIteratorType;
import com.amazonaws.services.dynamodbv2.model.StreamSpecification;
import com.amazonaws.services.dynamodbv2.model.StreamViewType;
import com.amazonaws.services.dynamodbv2.util.Tables;
public class StreamsExample {
private static AmazonDynamoDBClient dynamoDBClient =
new AmazonDynamoDBClient(new ProfileCredentialsProvider());
private static AmazonDynamoDBStreamsClient streamsClient =
new AmazonDynamoDBStreamsClient(new ProfileCredentialsProvider());
public static void main(String args[]) {
dynamoDBClient.setEndpoint("InsertDbEndpointHere");
streamsClient.setEndpoint("InsertStreamEndpointHere");
// table creation
String tableName = "MyTestingTable";
ArrayList<AttributeDefinition> attributeDefinitions =
new ArrayList<AttributeDefinition>();
attributeDefinitions.add(new AttributeDefinition()
.withAttributeName("ID")
.withAttributeType("N"));
ArrayList<KeySchemaElement> keySchema = new
ArrayList<KeySchemaElement>();
keySchema.add(new KeySchemaElement()
.withAttributeName("ID")
.withKeyType(KeyType.HASH)); //Partition key
StreamSpecification streamSpecification = new StreamSpecification();
streamSpecification.setStreamEnabled(true);
streamSpecification.setStreamViewType(StreamViewType.NEW_AND_OLD_IMAGES);
CreateTableRequest createTableRequest = new CreateTableRequest()
.withTableName(tableName)
.withKeySchema(keySchema)
.withAttributeDefinitions(attributeDefinitions)
.withProvisionedThroughput(new ProvisionedThroughput()
.withReadCapacityUnits(1L)
.withWriteCapacityUnits(1L))
.withStreamSpecification(streamSpecification);
System.out.println("Executing CreateTable for " + tableName);
dynamoDBClient.createTable(createTableRequest);
System.out.println("Creating " + tableName);
try {
Tables.awaitTableToBecomeActive(dynamoDBClient, tableName);
} catch (InterruptedException e) {
e.printStackTrace();
}
// Get the table's stream settings
DescribeTableResult describeTableResult =
dynamoDBClient.describeTable(tableName);
String myStreamArn = describeTableResult.getTable().getLatestStreamArn();
StreamSpecification myStreamSpec =
describeTableResult.getTable().getStreamSpecification();
System.out.println("Current stream ARN for " + tableName + ": "+ myStreamArn);
System.out.println("Stream enabled: "+ myStreamSpec.getStreamEnabled());
System.out.println("Update view type: "+ myStreamSpec.getStreamViewType());
// Add an item
int numChanges = 0;
System.out.println("Making some changes to table data");
Map<String, AttributeValue> item = new HashMap<String, AttributeValue>();
item.put("ID", new AttributeValue().withN("222"));
item.put("Alert", new AttributeValue().withS("item!"));
dynamoDBClient.putItem(tableName, item);
numChanges++;
// Update the item
Map<String, AttributeValue> key = new HashMap<String, AttributeValue>();
key.put("ID", new AttributeValue().withN("222"));
Map<String, AttributeValueUpdate> attributeUpdates =
new HashMap<String, AttributeValueUpdate>();
attributeUpdates.put("Alert", new AttributeValueUpdate()
.withAction(AttributeAction.PUT)
.withValue(new AttributeValue().withS("modified item")));
dynamoDBClient.updateItem(tableName, key, attributeUpdates);
numChanges++;
// Delete the item
dynamoDBClient.deleteItem(tableName, key);
numChanges++;
// Get stream shards
DescribeStreamResult describeStreamResult =
streamsClient.describeStream(new DescribeStreamRequest()
.withStreamArn(myStreamArn));
String streamArn =
describeStreamResult.getStreamDescription().getStreamArn();
List<Shard> shards =
describeStreamResult.getStreamDescription().getShards();
// Process shards
for (Shard shard : shards) {
String shardId = shard.getShardId();
System.out.println("Processing " + shardId + " in "+ streamArn);
// Get shard iterator
GetShardIteratorRequest getShardIteratorRequest = new
GetShardIteratorRequest()
.withStreamArn(myStreamArn)
.withShardId(shardId)
.withShardIteratorType(ShardIteratorType.TRIM_HORIZON);
GetShardIteratorResult getShardIteratorResult =
streamsClient.getShardIterator(getShardIteratorRequest);
String nextItr = getShardIteratorResult.getShardIterator();
while (nextItr != null && numChanges > 0) {
// Read data records with iterator
GetRecordsResult getRecordsResult =
streamsClient.getRecords(new GetRecordsRequest().
withShardIterator(nextItr));
List<Record> records = getRecordsResult.getRecords();
System.out.println("Pulling records...");
for (Record record : records) {
System.out.println(record);
numChanges--;
}
nextItr = getRecordsResult.getNextShardIterator();
}
}
}
}
एक अनुरोध के असफल प्रसंस्करण पर, डायनेमोडी एक त्रुटि फेंकता है। प्रत्येक त्रुटि में निम्नलिखित घटक होते हैं: HTTP स्थिति कोड, अपवाद नाम और संदेश। त्रुटि प्रबंधन आपके SDK पर टिकी हुई है, जो त्रुटियों या आपके स्वयं के कोड का प्रचार करता है।
कोड और संदेश
अपवाद अलग-अलग HTTP हेडर स्टेटस कोड में आते हैं। 4xx और 5xx अनुरोध मुद्दों और AWS से संबंधित त्रुटियां रखते हैं।
HTTP 4xx श्रेणी में अपवादों का चयन इस प्रकार है -
AccessDeniedException - क्लाइंट अनुरोध पर सही तरीके से हस्ताक्षर करने में विफल रहा।
ConditionalCheckFailedException - झूठी स्थिति का मूल्यांकन किया गया।
IncompleteSignatureException - अनुरोध में अपूर्ण हस्ताक्षर शामिल थे।
HTTP 5xx श्रेणी में अपवाद इस प्रकार हैं -
- आंतरिक सर्वर त्रुटि
- सेवा उप्लब्ध् नहीं है
रिट्रीट और बैकऑफ़ एल्गोरिदम
त्रुटियाँ कई प्रकार के स्रोतों से आती हैं जैसे सर्वर, स्विच, लोड बैलेंसर, और संरचना और सिस्टम के अन्य टुकड़े। सामान्य समाधानों में साधारण रिट्रीट होते हैं, जो विश्वसनीयता का समर्थन करते हैं। सभी एसडीके में यह तर्क स्वचालित रूप से शामिल है, और आप अपने आवेदन की आवश्यकताओं के अनुरूप रिट्रीट पैरामीटर सेट कर सकते हैं।
For example - Java रिट्रीट को रोकने के लिए एक अधिकतमErrorRetry मान प्रदान करता है।
अमेज़न प्रवाह को नियंत्रित करने के लिए रिट्रीट के अलावा एक बैकऑफ़ समाधान का उपयोग करने की सलाह देता है। इसमें रीट्रीट के बीच उत्तरोत्तर वृद्धि की अवधि होती है और अंततः काफी कम समय के बाद रुक जाती है। नोट SDK स्वचालित रिट्रीव करते हैं, लेकिन घातीय बैकऑफ़ नहीं।
निम्नलिखित कार्यक्रम रिट्री बैकऑफ का एक उदाहरण है -
public enum Results {
SUCCESS,
NOT_READY,
THROTTLED,
SERVER_ERROR
}
public static void DoAndWaitExample() {
try {
// asynchronous operation.
long token = asyncOperation();
int retries = 0;
boolean retry = false;
do {
long waitTime = Math.min(getWaitTime(retries), MAX_WAIT_INTERVAL);
System.out.print(waitTime + "\n");
// Pause for result
Thread.sleep(waitTime);
// Get result
Results result = getAsyncOperationResult(token);
if (Results.SUCCESS == result) {
retry = false;
} else if (Results.NOT_READY == result) {
retry = true;
} else if (Results.THROTTLED == result) {
retry = true;
} else if (Results.SERVER_ERROR == result) {
retry = true;
} else {
// stop on other error
retry = false;
}
} while (retry && (retries++ < MAX_RETRIES));
}
catch (Exception ex) {
}
}
public static long getWaitTime(int retryCount) {
long waitTime = ((long) Math.pow(3, retryCount) * 100L);
return waitTime;
}
विभिन्न स्रोतों और तत्वों के साथ काम करते समय कुछ प्रथाएं कोड का अनुकूलन करती हैं, त्रुटियों को रोकती हैं और थ्रूपुट लागत को कम करती हैं।
निम्नलिखित डायनमोबी में सबसे महत्वपूर्ण और आमतौर पर इस्तेमाल की जाने वाली सर्वोत्तम प्रथाओं में से कुछ हैं।
टेबल
तालिकाओं के वितरण का अर्थ है सभी तालिका वस्तुओं में समान रूप से पढ़ने / लिखने की गतिविधि के लिए सर्वोत्तम दृष्टिकोण का प्रसार।
टेबल आइटम पर समान डेटा एक्सेस के लिए लक्ष्य। इष्टतम थ्रूपुट उपयोग प्राथमिक कुंजी चयन और आइटम वर्कलोड पैटर्न पर टिकी हुई है। विभाजन कुंजी मूल्यों पर समान रूप से कार्यभार फैलाएं। भारी मात्रा में उपयोग किए जाने वाले महत्वपूर्ण कुंजी मानों जैसी छोटी चीज़ों से बचें। अलग-अलग विभाजन कुंजी मानों की बड़ी मात्रा जैसे बेहतर विकल्पों के लिए विकल्प।
विभाजन के व्यवहार की समझ हासिल करें। डायनेमोबीडी द्वारा स्वचालित रूप से आवंटित अनुमानित विभाजन।
डायनेमोडी ने फट थ्रूपुट उपयोग की पेशकश की, जो अप्रयुक्त थ्रूपुट को "फट" शक्ति के लिए आरक्षित करता है। इस विकल्प के भारी उपयोग से बचें क्योंकि फटने से बड़ी मात्रा में थ्रूपुट की खपत होती है; इसके अलावा, यह एक विश्वसनीय संसाधन साबित नहीं होता है।
अपलोड करने पर, बेहतर प्रदर्शन प्राप्त करने के लिए डेटा वितरित करें। सभी आवंटित सर्वरों पर समवर्ती अपलोड करके इसे लागू करें।
कैश अक्सर डेटाबेस के बजाय कैश को रीड एक्टिविटी को लोड करने के लिए उपयोग किया जाता है।
आइटम
थ्रॉटलिंग, प्रदर्शन, आकार और पहुंच लागत आइटम के साथ सबसे बड़ी चिंता का विषय है। एक-से-कई तालिकाओं के लिए ऑप्ट। एक्सेस पैटर्न से मिलान करने के लिए विशेषताएँ और विभाजन तालिकाएँ निकालें। आप इस सरल दृष्टिकोण के माध्यम से नाटकीय रूप से दक्षता में सुधार कर सकते हैं।
उन्हें संग्रहीत करने से पहले बड़े मूल्यों को संपीड़ित करें। मानक संपीड़न उपकरणों का उपयोग करें। S3 जैसे बड़े विशेषता मानों के लिए वैकल्पिक संग्रहण का उपयोग करें। आप S3 में ऑब्जेक्ट को स्टोर कर सकते हैं, और आइटम में एक पहचानकर्ता।
आभासी आइटम टुकड़ों के माध्यम से कई मदों में बड़ी विशेषताओं को वितरित करें। यह आइटम आकार की सीमाओं के लिए एक समाधान प्रदान करता है।
क्वेरी और स्कैन
क्वेरी और स्कैन मुख्य रूप से थ्रूपुट खपत की चुनौतियों से पीड़ित हैं। फट से बचें, जो आमतौर पर जोरदार सुसंगत रीडिंग पर स्विच करने जैसी चीजों के परिणामस्वरूप होता है। कम-रिसोर्स तरीके (जैसे, थ्रॉटलिंग के साथ बैकग्राउंड फ़ंक्शन) में समानांतर स्कैन का उपयोग करें। इसके अलावा, केवल उन्हें बड़े तालिकाओं के साथ नियोजित करें, और ऐसी स्थितियां जहां आप पूरी तरह से उपयोग नहीं करते हैं या स्कैन ऑपरेशन खराब प्रदर्शन की पेशकश करते हैं।
स्थानीय माध्यमिक संकेत
अनुक्रमणिका थ्रूपुट और भंडारण लागत और प्रश्नों की दक्षता के क्षेत्रों में मुद्दों को प्रस्तुत करती है। जब तक आप अक्सर विशेषताओं को क्वेरी नहीं करते, तब तक अनुक्रमण से बचें। अनुमानों में, बुद्धिमानी से चुनें क्योंकि वे अनुक्रमणिका को फूंकते हैं। केवल उन भारी उपयोग का चयन करें।
उपयोग किए गए विरल इंडेक्स, जिसका अर्थ इंडेक्स है जिसमें सभी टेबल आइटम में सॉर्ट कीज़ दिखाई नहीं देती हैं। वे अधिकांश टेबल आइटम में मौजूद विशेषताओं पर प्रश्नों का लाभ उठाते हैं।
आइटम संग्रह (सभी टेबल आइटम और उनके सूचकांक) के विस्तार पर ध्यान दें। जोड़ें / अपडेट संचालन के कारण तालिका और अनुक्रमणिका दोनों विकसित होते हैं, और 10GB संग्रह की सीमा बनी रहती है।
वैश्विक माध्यमिक संकेत
अनुक्रमणिका थ्रूपुट और भंडारण लागत और प्रश्नों की दक्षता के क्षेत्रों में मुद्दों को प्रस्तुत करती है। फैलाने वाली प्रमुख विशेषताओं का विकल्प, जो टेबल में फैलते हुए पढ़ना / लिखना पसंद करते हैं, कार्यभार एकरूपता प्रदान करते हैं। उन विशेषताओं को चुनें जो समान रूप से डेटा फैलाती हैं। इसके अलावा, विरल सूचकांक का उपयोग करें।
डेटा की मामूली मात्रा का अनुरोध करने वाले प्रश्नों में तेजी से खोज के लिए वैश्विक माध्यमिक सूचकांकों का शोषण करें।