java - 通过 Java 代码将多个项目放入 DynamoDB

标签 java amazon-web-services sdk amazon-dynamodb amazon-kinesis

我想使用亚马逊SDK的batchWriteItem方法将很多项目放入表中。 我从 Kinesis 检索了这些项目,它有很多碎片。 我对一项项目使用了这种方法:

public static void addSingleRecord(Item thingRecord) {


    // Add an item
    try
    {

        DynamoDB dynamo = new DynamoDB(dynamoDB); 
        Table table = dynamo.getTable(dataTable);
        table.putItem(thingRecord);

    } catch (AmazonServiceException ase) {
        System.out.println("addThingsData request  "
                + "to AWS was rejected with an error response for some reason.");
        System.out.println("Error Message:    " + ase.getMessage());
        System.out.println("HTTP Status Code: " + ase.getStatusCode());
        System.out.println("AWS Error Code:   " + ase.getErrorCode());
        System.out.println("Error Type:       " + ase.getErrorType());
        System.out.println("Request ID:       " + ase.getRequestId());
    } catch (AmazonClientException ace) {
        System.out.println("addThingsData - Caught an AmazonClientException, which means the client encountered "
                + "a serious internal problem while trying to communicate with AWS, "
                + "such as not being able to access the network.");
        System.out.println("Error Message: " + ace.getMessage());
    }
}

public static void addThings(String thingDatum) {
    Item itemJ2;
    itemJ2 = Item.fromJSON(thingDatum);
    addSingleRecord(itemJ2);

}

该项目来自:

private void processSingleRecord(Record record) {
    // TODO Add your own record processing logic here


    String data = null;
    try {


        // For this app, we interpret the payload as UTF-8 chars.
        data = decoder.decode(record.getData()).toString();
        System.out.println("**processSingleRecord - data " + data);
        AmazonDynamoDBSample.addThings(data);

    } catch (NumberFormatException e) {
        LOG.info("Record does not match sample record format. Ignoring record with data; " + data);
    } catch (CharacterCodingException e) {
        LOG.error("Malformed data: " + data, e);
    }
}

现在如果我想放很多记录,我会使用:

    public static void writeMultipleItemsBatchWrite(Item thingRecord) {
    try {                    


            dataTableWriteItems.addItemToPut(thingRecord);
        System.out.println("Making the request.");
        BatchWriteItemOutcome outcome = dynamo.batchWriteItem(dataTableWriteItems);
        do {

                // Check for unprocessed keys which could happen if you exceed provisioned throughput

                Map<String, List<WriteRequest>> unprocessedItems = outcome.getUnprocessedItems();

                if (outcome.getUnprocessedItems().size() == 0) {
                    System.out.println("No unprocessed items found");
                } else {
                    System.out.println("Retrieving the unprocessed items");
                    outcome = dynamo.batchWriteItemUnprocessed(unprocessedItems);
                }

            } while (outcome.getUnprocessedItems().size() > 0);

    }  catch (Exception e) {
        System.err.println("Failed to retrieve items: ");
        e.printStackTrace(System.err);
    }  

}

但是我怎样才能发送最后一组呢?因为我只有在有 25 件商品时才发送,但最后数量会更少。

最佳答案

您可以使用 Document SDK 一次向 DynamoDB 表写入一个项目在 Lambda function附于您的Kinesis Stream使用 PutItem 或 UpdateItem。这样,您可以在流记录出现在流中时对其使用react,而不必担心是否还有更多记录需要处理。在幕后,BatchWriteItem 消耗与相应 PutItem 调用相同数量的写入容量单位。 BatchWriteItem 将与批处理中耗时最长的 PUT 一样延迟。因此,使用 BatchWriteItem 时,您可能会遇到比并行 PutItem/UpdateItem 调用更高的平均延迟。

关于java - 通过 Java 代码将多个项目放入 DynamoDB,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30525108/

相关文章:

java - 串口版uid和eclipse

java - 制作 MacOS 守护程序时我可以选择哪些语言?

java正则表达式拆分字符串

Amazon S3 上的 SSL 为 "static website"

ios - Box iOS SDK - 类消息的接收者 'BoxSearchRequestBuilder' 是前向声明

java - Hibernate外键映射?

python - AWS Lambda 长时间运行的 http 请求

amazon-web-services - AWSCli dynamodb update-item 命令语法

java - Android 仅使用 API 20 : Android 4. 4 (KitKat Wear) 进行编译

android - 在 Google SDK 内部开发与外部开发