DynamoDB - Пакетная запись

Пакетная запись работает с несколькими элементами, создавая или удаляя несколько элементов. Эти операции используютBatchWriteItem, который имеет ограничения не более 16 МБ записи и 25 запросов. Размер каждого элемента составляет 400 КБ. Пакетная запись также не может выполнять обновления элементов.

Что такое пакетная запись?

Пакетная запись может управлять элементами в нескольких таблицах. Вызов операции происходит для каждого отдельного запроса, что означает, что операции не влияют друг на друга, и разрешены гетерогенные сочетания; например, одинPutItem и три DeleteItemзапросов в пакете, при этом сбой запроса PutItem не влияет на остальные. Неудачные запросы приводят к тому, что операция возвращает информацию (ключи и данные), относящуюся к каждому неудачному запросу.

Note- Если DynamoDB возвращает какие-либо элементы, не обрабатывая их, повторите попытку; однако используйте метод отката, чтобы избежать сбоя еще одного запроса из-за перегрузки.

DynamoDB отклоняет операцию пакетной записи, когда подтверждается одно или несколько из следующих утверждений:

  • Запрос превышает предоставленную пропускную способность.

  • Запрос пытается использовать BatchWriteItems чтобы обновить элемент.

  • Запрос выполняет несколько операций с одним элементом.

  • Таблицы запросов не существуют.

  • Атрибуты элемента в запросе не соответствуют цели.

  • Запросы превышают ограничения по размеру.

Пакетная запись требует определенных RequestItem параметры -

  • Операции удаления необходимы DeleteRequest ключ subelements означает имя и значение атрибута.

  • В PutRequest предметы требуют Item subelement что означает атрибут и карту значений атрибутов.

Response - Успешная операция приводит к ответу HTTP 200, в котором указываются такие характеристики, как потребленные единицы мощности, метрики обработки таблиц и любые необработанные элементы.

Пакетная запись с помощью Java

Выполните пакетную запись, создав экземпляр класса DynamoDB, 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);

Следующая программа - еще один более крупный пример для лучшего понимания того, как пакетная запись пишет с помощью Java.

Note- В следующем примере может быть использован ранее созданный источник данных. Перед попыткой выполнения приобретите вспомогательные библиотеки и создайте необходимые источники данных (таблицы с требуемыми характеристиками или другие источники, на которые есть ссылки).

В этом примере также используется Eclipse IDE, файл учетных данных AWS и AWS Toolkit в рамках проекта Eclipse AWS 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); 
      }   
   } 
}