डायनमोीडी - बैच लेखन
बैच लेखन कई वस्तुओं को बनाने या हटाने के द्वारा कई मदों पर काम करता है। ये ऑपरेशन उपयोग करते हैं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- निम्नलिखित उदाहरण पहले से बनाए गए डेटा स्रोत को मान सकते हैं। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ टेबल, या अन्य संदर्भित स्रोत)।
यह उदाहरण ग्रहण आईडीई, एक एडब्ल्यूएस क्रेडेंशियल फ़ाइल और एडब्ल्यूएस टूलकिट को एक्लिप्स एईए जावा प्रोजेक्ट के भीतर भी उपयोग करता है।
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);
}
}
}