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