AWS SNS - 如何获取由发布者 lambda 输出触发的订阅者 lambda

Pro*_*ova 4 amazon-web-services amazon-sns aws-lambda

我有一个 lambda 函数,它发送邮件并MessageID在电子邮件发送成功时返回as 输出,如果发送失败则返回错误消息。现在我想创建一个架构,将返回的电子邮件状态保存在 SNS 主题中。将有另一个 Lambda 函数作为订阅者,它将由 SNS 主题的电子邮件状态触发。

示例:如果发布者 Lambda 返回MessageID,则订阅者 Lambda 将针对错误消息返回“是”“否”。有可能实现吗?如果没有,我可以去最近的地方是什么?

到目前为止我所做的

  1. 创建 SNS 主题
  2. 为主题创建了一个订阅者 Lambda 函数。在 Lambda 中为以下 SNS 主题添加了触发器。
  3. 在我要用作发布者的现有 Lambda 中添加了 SN​​S 客户端。如果邮件发送成功,此 Lambda 将返回 MessageID。
  4. 我向指定的 SNS 主题发布了一条简单的消息。

以下是文档之后的订阅者功能代码:

import json

def lambda_handler(event, context):
    # TODO implement
    return {
        # 'statusCode': 200,
        # 'body': json.dumps('Hello from Lambda!')
         message = json.loads(event['Records'][0]['Sns']['Message']) 
         print("JSON: " + json.dumps(message)) 
         return message
    }
Run Code Online (Sandbox Code Playgroud)

我将消息发布到 SNS 主题的代码:

sns_client = boto3.client('sns', aws_access_key_id=AWS_ACCESS_KEY, aws_secret_access_key=AWS_SECRET_KEY, region_name=AWS_REGION)

sns_response = sns_client.publish(
        TopicArn='my-ARN',    
        Message='Hello World',    
    )
Run Code Online (Sandbox Code Playgroud)

Séb*_*acq 7

我试图重现您的问题,但无法重现。我使用了 Javascript 和 Typescript,但这不应该是你的问题。

这是用于创建基础架构的 CDK 代码:

import cdk = require('@aws-cdk/core');

import sns = require('@aws-cdk/aws-sns');
import subs = require('@aws-cdk/aws-sns-subscriptions');

import lambda = require('@aws-cdk/aws-lambda');

export class CdkStack extends cdk.Stack {
  constructor(scope: cdk.Construct, id: string, props?: cdk.StackProps) {
    super(scope, id, props);

    let fn = new lambda.Function(this, 'SODemoFunction', {
      runtime: lambda.Runtime.NODEJS_10_X,
      code: lambda.Code.asset('./src'),
      handler: 'index.handler'
    });

    const topic = new sns.Topic(this, 'SODemoTopic', {
      displayName: 'StackOverflow Demo'
    });
    topic.addSubscription(new subs.LambdaSubscription(fn));

  }
}
Run Code Online (Sandbox Code Playgroud)

这是 Lambda 函数的 JS


exports.handler =  async function(event, context) {
    console.log("EVENT: \n" + JSON.stringify(event, null, 2));
    return event['Records'][0]['Sns']['Message']; 
}
Run Code Online (Sandbox Code Playgroud)

这是我发送消息的方式:


exports.handler =  async function(event, context) {
    console.log("EVENT: \n" + JSON.stringify(event, null, 2));
    return event['Records'][0]['Sns']['Message']; 
}
Run Code Online (Sandbox Code Playgroud)

这是我在 cloudwatch 日志中看到的

2019-07-27T01:29:13.981Z cc56486b-0a8f-4e7a-a880-1e09d7631b98 INFO EVENT:
{
    "Records": [
        {
            "EventSource": "aws:sns",
            "EventVersion": "1.0",
            "EventSubscriptionArn": "arn:aws:sns:eu-west-1:012345678912:CdkStack-SODemoTopicD9C61805:22d228db-9c3c-488d-84a3-cbdbf5e9d112",
            "Sns": {
                "Type": "Notification",
                "MessageId": "b73b0141-e7d1-50f0-93ae-54f44cf8bb78",
                "TopicArn": "arn:aws:sns:eu-west-1:012345678912:CdkStack-SODemoTopicD9C61805",
                "Subject": null,
                "Message": "hello world",
                "Timestamp": "2019-07-27T01:29:13.862Z",
                "SignatureVersion": "1",
                "Signature": "Xqy8DYPWu+ZFw0hU23C78CTuFB3DblDSrY+vY44sDFMLmuZjM/kaQNvTmHGlLEFcdG3MBQQYWtMc/VQjVXONeIuJr4S336IENPTWylwSNSKHi5kAD93EmDiLl2y3jW2CdsDN9/QwQ5aJQrIkIp91VnWmCx03kUqgzhMdvQ0bsz64EUN6vMpKDZ4oJ6Ug0zTPUwyvcEneMzYkaFISakZZr1SHZYfHp7bfqZVyc2fjOIHhFIyePbMOsGYpQC8CGgD8d2Yekv0f1wYQKn5At4aHWQ29ObyjdsnbYCwlAuej47n1qVwh9li7XKFsRqyqE562Ul7OdLwA1t8tZdYbYh6zjA==",
                "SigningCertUrl": "https://sns.eu-west-1.amazonaws.com/SimpleNotificationService-6aad65c2f9911b05cd53efda11f913f9.pem",
                "UnsubscribeUrl": "https://sns.eu-west-1.amazonaws.com/?Action=Unsubscribe&SubscriptionArn=arn:aws:sns:eu-west-1:012345678912:CdkStack-SODemoTopicD9C61805:22d228db-9c3c-488d-84a3-cbdbf5e9d112",
                "MessageAttributes": {}
            }
        }
    ]
}
Run Code Online (Sandbox Code Playgroud)

你能在你身边试试吗?CDK 文档在这里https://docs.aws.amazon.com/cdk/latest/guide/getting_started.html