【发布时间】:2017-07-13 22:35:50
【问题描述】:
我在 AWS 中有 2 个 lambda 函数。
函数 A (FA),尝试同步调用函数 B (FB)。当 FA 尝试调用 FB 时,FA 将超时。 FA 永远不会到达 FA 内部的回调方法,并且 FB 在 cloudwatch 中没有日志说它被调用了。
我已将这两个功能设置为在同一区域、同一角色和无 VPC 中运行(因为我已阅读 VPC 可能会导致问题,但在相同的 VPC 和子网设置下也尝试过,但没有运气)
用户角色具有以下关联的权限
- AWSLambdaExecute
- AWSLambdaBasicExecutionRole
- AWSLambdaRole
功能A
exports.handler = (event, context, callback) => {
var aws = require('aws-sdk');
var lambda = new aws.Lambda({
region: 'ap-southeast-2'
});
lambda.invoke({
FunctionName: 'async-receiver-test'
}, function(error, data) {
console.log('inside return function');
if (error) {
context.done('error', error);
}
if(data.Payload){
context.succeed(data.Payload);
}
});
};
函数 B - (name => async-receiver-test)
exports.handler = (event, context, callback) => {
var eventItem = {id : 53148, name : "Let's get testing"};
callback(null, eventItem);
};
在控制台内运行函数A返回
报告请求 ID:2db82333-f9c3-11e6-8160-93bd7ddf5b19 持续时间:3000.43 毫秒计费持续时间:3000 毫秒内存大小:128 MB 最大内存使用量:25 MB
2017-02-23T12:25:39.363Z 2db82333-f9c3-11e6-8160-93bd7ddf5b19 任务在 3.00 秒后超时
在控制台内运行函数 B(持续时间:14.36 毫秒)
{ “身份证”:53148, "name": "让我们开始测试吧" }
因此,据我所知,这不是 FB 的问题,但由于某种原因,从 FA 调用时没有响应。
【问题讨论】:
标签: node.js amazon-web-services lambda aws-lambda