Lambda@Edge 在触发 Dynamodb 时给出 503 错误
Lambda@Edge when triggered Dynamodb giving 503 Error
我正在尝试通过云端查看器请求调用 Lambda
。这是我的 Lambda 代码
'use strict';
const AWS = require("aws-sdk");
const docClient = new AWS.DynamoDB.DocumentClient();
exports.handler = (event, context, callback) => {
/* Get request */
const request = event.Records[0].cf.request;
const requestbody = Buffer.from(request.body.data, 'base64').toString();
const data = JSON.parse(requestbody);
const Id = data.Name;
console.log(Id);
/* Generate body for response */
const body =
'<html>\n'
+ '<head><title>Hello From Lambda@Edge</title></head>\n'
+ '<body>\n'
+ '<h1>You clicked more than 10 Times </h1>\n'
+ '</body>\n'
+ '</html>';
var params = {
TableName: "Test",
ProjectionExpression: "#V,#N",
KeyConditionExpression: "#N = :v1",
ExpressionAttributeNames: {
"#N" : "Name",
"#V" : "Value"
},
ExpressionAttributeValues: {
":v1": Id
}
};
var querydb = docClient.query(params).promise();
querydb.then(function(data) {
console.log(data.Items[0].Value);
if(data.Items[0].Value >= 11){
const response = {
status: '200',
body: body,
};
callback(null, response);
}else {
callback(null,request);
}
}).catch(function(err) {
console.log(err);
});
};
当我通过控制台触发相同的 lambda 时,它给出了正确的响应。但是当我通过 Cloudfront 部署时,它给出了 503 Error
。但是我用代码 Dynamodb Client
尝试了相同的代码,它工作得很好。这是工作的
'use strict';
const AWS = require("aws-sdk");
const docClient = new AWS.DynamoDB.DocumentClient();
exports.handler = (event, context, callback) => {
/* Get request */
const request = event.Records[0].cf.request;
const requestbody = Buffer.from(request.body.data, 'base64').toString();
const data = JSON.parse(requestbody);
/* Generate body for response */
const body =
'<html>\n'
+ '<head><title>Hello From Lambda@Edge</title></head>\n'
+ '<body>\n'
+ '<h1>You clicked more than 10 Times </h1>\n'
+ '</body>\n'
+ '</html>';
if(data.Value >= 10){
const response = {
status: '200',
body: body,
};
callback(null, response);
}
else {
callback(null, request);
}
};
我已将完全的 dynamodb 权限授予 lambda@edge。
感谢任何帮助
谢谢
您在哪里为 DyanamoDB 指定了区域?
Lambda@Edge 可能在您的 DDB table 缺失的区域中执行。
查看 region's order of precedence. You can also look at this L@E workshop code and documentation 上的 AWS 文档,了解有关调用 DDB 的更多详细信息。
旁注:面向 Lambda 函数的查看器调用跨区域 dynamodb table 会对您的延迟产生负面影响。不确定您的用例,但看看是否可以将此调用移至面向源的事件或对 ddb 进行异步调用。
我正在尝试通过云端查看器请求调用 Lambda
。这是我的 Lambda 代码
'use strict';
const AWS = require("aws-sdk");
const docClient = new AWS.DynamoDB.DocumentClient();
exports.handler = (event, context, callback) => {
/* Get request */
const request = event.Records[0].cf.request;
const requestbody = Buffer.from(request.body.data, 'base64').toString();
const data = JSON.parse(requestbody);
const Id = data.Name;
console.log(Id);
/* Generate body for response */
const body =
'<html>\n'
+ '<head><title>Hello From Lambda@Edge</title></head>\n'
+ '<body>\n'
+ '<h1>You clicked more than 10 Times </h1>\n'
+ '</body>\n'
+ '</html>';
var params = {
TableName: "Test",
ProjectionExpression: "#V,#N",
KeyConditionExpression: "#N = :v1",
ExpressionAttributeNames: {
"#N" : "Name",
"#V" : "Value"
},
ExpressionAttributeValues: {
":v1": Id
}
};
var querydb = docClient.query(params).promise();
querydb.then(function(data) {
console.log(data.Items[0].Value);
if(data.Items[0].Value >= 11){
const response = {
status: '200',
body: body,
};
callback(null, response);
}else {
callback(null,request);
}
}).catch(function(err) {
console.log(err);
});
};
当我通过控制台触发相同的 lambda 时,它给出了正确的响应。但是当我通过 Cloudfront 部署时,它给出了 503 Error
。但是我用代码 Dynamodb Client
尝试了相同的代码,它工作得很好。这是工作的
'use strict';
const AWS = require("aws-sdk");
const docClient = new AWS.DynamoDB.DocumentClient();
exports.handler = (event, context, callback) => {
/* Get request */
const request = event.Records[0].cf.request;
const requestbody = Buffer.from(request.body.data, 'base64').toString();
const data = JSON.parse(requestbody);
/* Generate body for response */
const body =
'<html>\n'
+ '<head><title>Hello From Lambda@Edge</title></head>\n'
+ '<body>\n'
+ '<h1>You clicked more than 10 Times </h1>\n'
+ '</body>\n'
+ '</html>';
if(data.Value >= 10){
const response = {
status: '200',
body: body,
};
callback(null, response);
}
else {
callback(null, request);
}
};
我已将完全的 dynamodb 权限授予 lambda@edge。
感谢任何帮助 谢谢
您在哪里为 DyanamoDB 指定了区域?
Lambda@Edge 可能在您的 DDB table 缺失的区域中执行。
查看 region's order of precedence. You can also look at this L@E workshop code and documentation 上的 AWS 文档,了解有关调用 DDB 的更多详细信息。
旁注:面向 Lambda 函数的查看器调用跨区域 dynamodb table 会对您的延迟产生负面影响。不确定您的用例,但看看是否可以将此调用移至面向源的事件或对 ddb 进行异步调用。