消息发布到 SQS 时如何触发 lambda?

Posted

技术标签:

【中文标题】消息发布到 SQS 时如何触发 lambda?【英文标题】:How to trigger lambda when messages published to SQS? 【发布时间】:2019-08-16 23:20:18 【问题描述】:

我正在尝试实现将在消息发布到 SQS 时触发的 lambda1。我能够将消息发送到 SQS 队列并接收消息。 我按如下方式创建了 SQS lambda 模板:

  GetPatientStatusSQS:
    Type: AWS::SQS::Queue
    Properties:
      MaximumMessageSize: 1024
      QueueName: !Sub "$EnvironmentName-GetPatientStatusSQS"
      VisibilityTimeout: 30

我查看了 aws 文档,但找不到任何示例来说明当消息发布到 SQS 队列时如何触发 lambda。

我找到了这个链接Can an AWS Lambda function call another,但不确定这是否有用。

如何更新上面的 SQS 模板以触发 lambda1?

【问题讨论】:

【参考方案1】:

截至 2018 年 6 月 28 日,Lambda functions can be triggered by SQS events。

您需要做的就是将您的 Lambda 函数订阅到所需的 SQS 队列。

转到 SQS 的控制台,单击您的队列 -> 队列操作 -> 为 Lambda 函数配置触发器

设置您要向其发送消息的 Lambda 的 ARN,就是这样,您的函数现在将由 SQS 触发。

请记住,您的函数一次最多可以处理一批最多 10 条消息。

如果您认为可能会遇到并发问题,则可以将函数的并发限制为 1。

这是一个示例模板,可用于将 SQS 和 Lambda 连接在一起。

AWSTemplateFormatVersion: '2010-09-09'
Transform: AWS::Serverless-2016-10-31
Description: Example of processing messages on an SQS queue with Lambda
Resources:
  MySQSQueueFunction:
    Type: AWS::Serverless::Function
    Properties:
      Handler: index.handler
      Runtime: node8.10
      Events:
        MySQSEvent:
          Type: SQS
          Properties:
            Queue: !GetAtt MySqsQueue.Arn
            BatchSize: 10
  MySqsQueue:
    Type: AWS::SQS::Queue

来自docs

【讨论】:

感谢您的链接,有时很难跟上! 不客气。现在想象一下,对于我们这些不在 AWS 工作的普通人来说,要跟上你们每年发布大量服务的步伐是多么困难。请放慢速度:p @ThalesMinussi 谢谢,但我知道如何从 aws 控制台触发 lambda。我要问的是如何更新 SQS 模板 yaml 以触发另一个 lambda。 你能解释一下yaml中的一些部分吗?大概我们用 SQS 的 arn 替换“MySqsQueue.Arn”?下面几行的“MySqsQueue:”怎么样?这应该是 SQS 的名称吗? 终于找到错误了!取名很讲究!我为我的项目队列使用了标准的 CamelCase 名称,并没有考虑它,但由于某种原因,“DbfToEaLambdaQueue”不起作用,但“MySqsQueue”很好。只是发帖以防其他人被困在这个问题上!这是自动生成的 arn 必须满足的正则表达式: arn:(aws[a-zA-Z0-9-]*):([a-zA-Z0-9\-])+:([az]2( (-gov)|(-iso(b?)))?-[az]+-\d1)?:(\d12)?:(.*) 再次感谢泰雷兹

以上是关于消息发布到 SQS 时如何触发 lambda?的主要内容,如果未能解决你的问题,请参考以下文章

更长触发 lambda 的 SQS 消息

当消息存在于 SQS 队列中时触发 AWS 中的 Lambda 函数

在 SQS 消息触发的 Lambda 上跟踪 AWS API Gateway request_id

将消息属性从 lambda 添加回 SQS DLQ

如何从外部 SQS 队列活动触发 AWS Lambda 函数

AWS SQS 触发 Step Functions