【问题标题】:AWS lambda to send SNS "succeeds" but message not actually sentAWS lambda 发送 SNS“成功”但未实际发送消息
【发布时间】:2016-03-16 07:34:32
【问题描述】:

我编写了一个 AWS lambda 函数,用于在上传 S3 对象时发送文本消息。我已经确认订阅,我可以收到从 SNS 控制台发送的测试消息。

当我测试 lambda 时,所有日志都说方法成功但没有儿子消息到达。这是函数(大部分只是示例模板,但为了安全起见,我在这篇文章中更改了我的主题)。任何要测试/尝试下一步的提示都表示赞赏。

console.log('Loading function');
var aws = require('aws-sdk');
var s3 = new aws.S3({ apiVersion: '2006-03-01' });
exports.handler = function(event, context) {
    var bucket = event.Records[0].s3.bucket.name;
    var key = decodeURIComponent(event.Records[0].s3.object.key.replace(/\+/g, ' '));
    var params = {
        Bucket: bucket,
        Key: key
    };
    var sns = new aws.SNS();
    console.log('start of brians sns function')
    var pubResult = sns.publish({
        Message: 'Test publish to SNS from Lambda',
        TopicArn: 'arn:aws:sns:us-east-1:xxxxxxxxxxxx:lambdatop'
    }, function(err, data) {
        if (err) {
            console.log(err.stack);
            return;
        }
        console.log('push sent');
        console.log(data);
    });
    console.log('after sns publish:')
    console.log(pubResult)
    context.done(null, 'Brians Function Finished!');  
};

【问题讨论】:

    标签: node.js amazon-web-services lambda amazon-sns


    【解决方案1】:

    您在拨打publish() 之后立即拨打context.done()。 publish() 函数是一个异步调用,您无需等待它完成。另外,我不认为您的变量 pubResult 包含您期望的内容。

    试试这个:

    console.log('Loading function');
    var aws = require('aws-sdk');
    exports.handler = function(event, context) {
        var sns = new aws.SNS();
        console.log('start of brians sns function')
        sns.publish({
            Message: 'Test publish to SNS from Lambda',
            TopicArn: 'arn:aws:sns:us-east-1:xxxxxxxxxxxx:lambdatop'
        }, function(err, data) {
            if (err) {
                console.log(err.stack);
    
                // Notify Lambda that we are finished, but with errors
                context.done(err, 'Brians Function Finished with Errors!');  
                return;
            }
            console.log('push sent');
            console.log(data);
    
            // Notify Lambda that we are finished
            context.done(null, 'Brians Function Finished!');  
        });
    };
    

    【讨论】:

    • 谢谢...我现在得到:errorMessage": "进程在完成请求之前退出。您知道如何等待发布完成后再退出吗?
    • 您是否正在运行我的答案中的确切代码,并收到该错误消息?控制台日志中是否有任何错误?如果您完全复制/粘贴我的答案,并更新 TopicArn,它应该调用 SNS 发布函数,并且仅在调用发布回调后退出。
    • 这足以让我看到我实际上遇到了安全策略错误。解决了这个问题,它就像一个冠军。谢谢!
    • @MarkB,知道我们是否可以在上面的代码中动态获取此 TopicARN。这是我的问题,stackoverflow.com/questions/44937508/…
    【解决方案2】:

    解决此问题的另一种方法是将 SNS Publish 包装在 Promise 中,然后等待 Lambda 处理程序解决它。

    exports.handler = async (event) => {
        await publishSNS(record, process.env.TOPIC_ARN);
    }
    
    async function publishSNS(payload, topicArn) {
        await SNS.publish({
            Message: JSON.stringify(payload),
            TargetArn: topicArn
        }).promise().then((data) => {
            console.log('SNS push succeeded: ', data);
        }).catch((err) => {
            console.error(err);
        });
    }
    

    【讨论】:

      猜你喜欢
      • 2021-05-06
      • 1970-01-01
      • 2021-12-01
      • 2021-01-22
      • 2023-03-18
      • 1970-01-01
      • 2017-01-28
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多