DynamoDB-일괄 쓰기
일괄 쓰기는 여러 항목을 만들거나 삭제하여 여러 항목에 대해 작동합니다. 이러한 작업은BatchWriteItem, 16MB 쓰기 및 25 개 요청을 초과하지 않는 제한이 있습니다. 각 항목은 400KB 크기 제한을 따릅니다. 일괄 쓰기는 항목 업데이트도 수행 할 수 없습니다.
일괄 쓰기 란 무엇입니까?
일괄 쓰기는 여러 테이블에서 항목을 조작 할 수 있습니다. 작업 호출은 각 개별 요청에 대해 발생합니다. 즉, 작업이 서로 영향을주지 않으며 이기종 혼합이 허용됩니다. 예를 들어, 하나PutItem 그리고 세 DeleteItemPutItem 요청의 실패는 다른 요청에 영향을주지 않는 일괄 요청입니다. 요청이 실패하면 실패한 각 요청과 관련된 정보 (키 및 데이터)를 반환하는 작업이 발생합니다.
Note− DynamoDB가 항목을 처리하지 않고 반환하는 경우 다시 시도하십시오. 그러나 오버로딩에 따른 다른 요청 실패를 방지하려면 백 오프 방법을 사용하십시오.
DynamoDB는 다음 문 중 하나 이상이 사실 인 것으로 입증되면 일괄 쓰기 작업을 거부합니다.
요청이 프로비저닝 된 처리량을 초과합니다.
요청이 사용을 시도합니다. BatchWriteItems 항목을 업데이트합니다.
요청은 단일 항목에 대해 여러 작업을 수행합니다.
요청 테이블이 없습니다.
요청의 항목 속성이 대상과 일치하지 않습니다.
요청이 크기 제한을 초과합니다.
일괄 쓰기에는 특정 RequestItem 매개 변수-
삭제 작업 필요 DeleteRequest 키 subelements 속성 이름과 값을 의미합니다.
그만큼 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);
}
}
}