DynamoDB-일괄 쓰기

일괄 쓰기는 여러 항목을 만들거나 삭제하여 여러 항목에 대해 작동합니다. 이러한 작업은BatchWriteItem, 16MB 쓰기 및 25 개 요청을 초과하지 않는 제한이 있습니다. 각 항목은 400KB 크기 제한을 따릅니다. 일괄 쓰기는 항목 업데이트도 수행 할 수 없습니다.

일괄 쓰기 란 무엇입니까?

일괄 쓰기는 여러 테이블에서 항목을 조작 할 수 있습니다. 작업 호출은 각 개별 요청에 대해 발생합니다. 즉, 작업이 서로 영향을주지 않으며 이기종 혼합이 허용됩니다. 예를 들어, 하나PutItem 그리고 세 DeleteItemPutItem 요청의 실패는 다른 요청에 영향을주지 않는 일괄 요청입니다. 요청이 실패하면 실패한 각 요청과 관련된 정보 (키 및 데이터)를 반환하는 작업이 발생합니다.

Note− DynamoDB가 항목을 처리하지 않고 반환하는 경우 다시 시도하십시오. 그러나 오버로딩에 따른 다른 요청 실패를 방지하려면 백 오프 방법을 사용하십시오.

DynamoDB는 다음 문 중 하나 이상이 사실 인 것으로 입증되면 일괄 쓰기 작업을 거부합니다.

  • 요청이 프로비저닝 된 처리량을 초과합니다.

  • 요청이 사용을 시도합니다. BatchWriteItems 항목을 업데이트합니다.

  • 요청은 단일 항목에 대해 여러 작업을 수행합니다.

  • 요청 테이블이 없습니다.

  • 요청의 항목 속성이 대상과 일치하지 않습니다.

  • 요청이 크기 제한을 초과합니다.

일괄 쓰기에는 특정 RequestItem 매개 변수-

  • 삭제 작업 필요 DeleteRequestsubelements 속성 이름과 값을 의미합니다.

  • 그만큼 PutRequest 항목에는 Item subelement 속성 및 속성 값 맵을 의미합니다.

Response − 작업이 성공하면 사용 된 용량 단위, 테이블 처리 메트릭 및 처리되지 않은 항목과 같은 특성을 나타내는 HTTP 200 응답이 발생합니다.

자바로 일괄 쓰기

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 자격 증명 파일 및 Eclipse AWS Java 프로젝트 내에서 AWS Toolkit을 사용합니다.

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); 
      }   
   } 
}