AWS Lambda 在终止前不会解决所有承诺

leo*_*xyz 1 javascript amazon-web-services promise aws-lambda

我正在努力使用一个简单的 AWS Lambda 函数,该函数应该将一些消息发布到 SNS 主题。

我的电子邮件地址已订阅该主题并且订阅已确认。

该主题与我的 lambda 函数位于同一区域。

该函数与附加了两个策略的 IAM 角色关联:

  1. 默认策略 AWSLambdaBasicExecutionRole
  2. 允许该函数写入我的 SNS 主题的另一个策略

政策:

{
    "Version": "2012-10-17",
    "Statement": [
        {
            "Sid": "VisualEditor0",
            "Effect": "Allow",
            "Action": "sns:Publish",
            "Resource": "arn:aws:sns:eu-west-1:XXXXXXXXXXXX:YYYYYYYYYYYYYYYYYYY"
        }
    ]
}
Run Code Online (Sandbox Code Playgroud)

这是我的函数代码,在Cloud9上开发。

const AWS = require("aws-sdk");
const sns = new AWS.SNS({region:'eu-west-1'});

exports.handler = async (event, context, callback) => {

    const apiResponse = new Promise((resolve, reject) => {
        setTimeout(() => resolve(['one', 'two', 'three']), 500)
    });

    const messages = await apiResponse;

    const promises = [];

    messages.forEach(txt => {
       promises.push(sns.publish({
           Message: txt,
           Subject: txt,
           TopicArn: 'arn:aws:sns:eu-west-1:xxxxxxxxxxxx:MyWebsiteContactForm'
       }).promise());
    });

    console.log(promises);

    Promise.all(promises,
        function (values) {
            console.log(values);
            callback(null, values);
        },
        function(err) {
            console.error(Error(err));
            callback(Error(err));
        }
    );
};
Run Code Online (Sandbox Code Playgroud)

执行这段代码的结果就是这个预期的输出,但它从不记录任何内容Promise.all()

[ Promise { <pending> },
  Promise { <pending> },
  Promise { <pending> } ]
Run Code Online (Sandbox Code Playgroud)

就像 Lambda 在解决承诺之前终止一样,但我不明白为什么。我按照这里的Promise.all()建议使用

提前致谢

Eli*_*res 5

由于您在处理程序上使用async关键字,因此 lambda 将等待它并退出。您的async函数不包含任何await,因此它将立即运行。

要修复它,您可以:

  1. 删除async关键字,以便 Lambda 将等待调用calllback,或者;
  2. 使用await 到你的Promise.all(),如图所示:
const AWS = require("aws-sdk");
const sns = new AWS.SNS({region:'eu-west-1'});

exports.handler = async (event, context) => {

    const promises = []; 

    ['one', 'two', 'three'].forEach(txt => {
       promises.push(sns.publish({
           Message: txt,
           Subject: txt,
           TopicArn: 'arn:aws:sns:eu-west-1:XXXXXXXXXXXX:YYYYYYYYYYYYYYYYYYY'
       }).promise());
    });

    console.log(promises);

    try {
        let values = await Promise.all(promises);
        // do any transformations here
        return values;
    } catch (err) {
        console.error(err);
        // deal with errors here or re-throw the error if you need that
        // the lambda function results in error too.
        throw(err);
        // Or
        return "something went wrong";
    }
};
Run Code Online (Sandbox Code Playgroud)

有关更多详细信息,请参阅https://docs.aws.amazon.com/lambda/latest/dg/nodejs-prog-model-handler.html


归档时间:

查看次数:

2696 次

最近记录:

5 年,12 月 前