您可以在哪里更改触发 AWS Lambda 函数的 SQS 队列的批处理大小?

J T*_*J T 12 amazon-sqs amazon-web-services aws-lambda

我可以发誓,有一种简单的方法可以更改配置为 Lambda 触发器的 SQS 队列的批量大小,但截至 2020 年 7 月,我再也找不到发生这种情况的地方。这可能与目前在 AWS 顶部宣传的“新 SQS 控制台体验”有关。

我可以看到队列的当前批次大小(屏幕截图),但该数字不可编辑。我也没有在 SQS 界面中看到与批量大小相关的任何内容。我当前的 IAM 凭证可能无法更改批量大小,并且对我隐藏。有谁知道可以在哪里更改此值?

来自 AWS 的屏幕截图,显示当前批次大小的显示位置

Joh*_*ein 13

此限制与 Amazon SQS控制台无关

与 AWS Lambda 相关,因为 Lambda 服务负责轮询 SQS 队列并指定要检索的批次大小。

您是正确的,在 Lambda 控制台中没有编辑批量大小的功能。

来自update-event-source-mapping — AWS CLI 命令参考,这里是一个可以更新批量大小的 AWS CLI 命令:

aws lambda update-event-source-mapping \
    --uuid  "a1b2c3d4-5678-90ab-cdef-11111EXAMPLE" \
    --batch-size 8
Run Code Online (Sandbox Code Playgroud)

输出:

{
    "UUID": "a1b2c3d4-5678-90ab-cdef-11111EXAMPLE",
    "StateTransitionReason": "USER_INITIATED",
    "LastModified": 1569284520.333,
    "BatchSize": 8,
    "State": "Updating",
    "FunctionArn": "arn:aws:lambda:us-west-2:123456789012:function:my-function",
    "EventSourceArn": "arn:aws:sqs:us-west-2:123456789012:mySQSqueue"
}
Run Code Online (Sandbox Code Playgroud)

或者,只需删除 Lambda 控制台中的触发器并创建一个新触发器。


Mar*_*cin 12

SQS 也不例外。将同样适用于DynamoDB和室壁运动流。我认为原因是所有三个服务通过事件源映射与 lambda 一起使用。没有其他东西在使用映射。

但是,event source mappings也无法通过控制台进行更新。您可以为此使用 CLI 或 SDK,但这也需要获取UUID要修改的映射。遗憾的是,控制台中没有提供 UUID

要在 CLI 中使用,您必须分两步完成

1 获取 UUID

aws lambda list-event-source-mappings --query 'EventSourceMappings[].[UUID, EventSourceArn]' --output table
Run Code Online (Sandbox Code Playgroud)
-------------------------------------------------------------------------------------------------------------------------------
|                                                   ListEventSourceMappings                                                   |
+---------------------------------------+-------------------------------------------------------------------------------------+
|  5ab44863-82c2-4acc-b9dc-b14ad368effa |  arn:aws:kinesis:us-east-1:xxxxx:stream/kstream                              |
|  7479947c-bde5-4041-a438-5eb08f350505 |  arn:aws:dynamodb:us-east-1:xxxx:table/test/stream/2020-07-28T23:13:41.006  |
|  40040139-32fb-4297-b094-3f08368c980c |  arn:aws:sqs:us-east-1:xxxxx:Messages                                        |
|  a2b22aa6-f37a-4603-895b-3a044661ebdf |  arn:aws:sqs:us-east-1:xxx:test-queue                                      |
+---------------------------------------+-------------------------------------------------------------------------------------+

Run Code Online (Sandbox Code Playgroud)

2. 更新映射(例如对于 SQS)

aws lambda update-event-source-mapping --uuid a2b22aa6-f37a-4603-895b-3a044661ebdf --batch-size 5
Run Code Online (Sandbox Code Playgroud)
{
    "UUID": "a2b22aa6-f37a-4603-895b-3a044661ebdf",
    "BatchSize": 5,
    "EventSourceArn": "arn:aws:sqs:us-east-1:xxx:test-queue",
    "FunctionArn": "arn:aws:lambda:us-east-1:xxxx:function:testsfd",
    "LastModified": 1595978738.458,
    "State": "Updating",
    "StateTransitionReason": "USER_INITIATED"
}

Run Code Online (Sandbox Code Playgroud)