0

我正在尝试将 DAX 示例 getitem-test.js 作为 lambda 运行。(文档链接)。我修改了代码以从我创建的 daxclient 中读取。但是 daxClient.get 从 lambda 返回错误

START RequestId:bb657a02-05b1-11e8-804d-a1d27ac0e9f7 版本:$LATEST 2018-01-30T11:36:03.363Z bb657a02-05b1-11e8-804d-a1d27ac0e9f7 无法读取项目。错误 JSON:{“time”:1517312163361,“code”:“ValidationException”,“retryable”:true,“requestId”:“AVI5QK8LN9S41B64JTTJVECLR3VV4KQNSO5AEMVJF66Q9ASUAAJG”,“statusCode”:“400”,“_tubeInvalid”:false,“waitForRecoveryBeforeRetrying”:错误的 }

我已经使用 dynamodbclient 设置了 dynamo db 表。设置 VPC、子网等。但我没有运气从 DAX 读取数据。知道可能是什么问题。

以下是我使用的代码:

var region = "eu-west-1";
AWS.config.update({
    region: region
});
var daxClient = null;
var dax = new AmazonDaxClient({ endpoints: ["mydax.e02jim.clustercfg.dax.euw1.cache.amazonaws.com:8111"], region: region })
daxClient = new AWS.DynamoDB.DocumentClient({ service: dax });
var tableName = "TryDaxTable";
var params = {
    TableName: tableName,
    Key: {
        "pk": 7,
        "sk": 1
    }
};
daxClient.get(params, function (err, data) {
    if (err) {
        console.error("Unable to read item. Error JSON:", 
JSON.stringify(err, null, 2));
    } else {
        console.log("success");
    }
});

我可以使用var ddbClient = new AWS.DynamoDB.DocumentClient() 而不是得到结果daxClient

我的 lambda 函数也超时了

4

1 回答 1

0

发现是权限问题。我的集群的 IAM 角色无权访问 DynamoDB 表。

关于 lambda 超时,我在谷歌搜索后最后添加了以下代码

context.callbackWaitsForEmptyEventLoop = false
callback(null, "success");
于 2018-02-02T04:02:47.537 回答