【发布时间】:2020-08-12 03:26:34
【问题描述】:
我想根据上一步的结果动态选择 AWS Lambda 工作程序。类似于{"Resource": "$.worker_arn"}。
"RunWorkers": {
"Type": "Map",
"MaxConcurrency": 0,
"InputPath": "$.output",
"ResultPath": "$.raw_result",
"Iterator": {
"StartAt": "CallWorkerLambda",
"States": {
"CallWorkerLambda": {
"Type": "Task",
"Resource": "$$.worker_arn",
"End": true
}
}
},
"Next": "Aggregate"
},
上一步的输入预期如下:
[{"worker_arn":..., "output":1}, {"worker_arn":..., "output":1}, ...],
其中worker_arn 在所有工作人员中都是相同的。
当我编写这样的管道时,linter 抱怨它需要一个 ARN。
有没有比将我的工人 lambda 包装到另一个 lambda 更好的选择?
【问题讨论】:
-
我能想到的一个解决方案是动态创建您的状态机,您可以在其中放置您想要的任何 Lambda arn。请参考这个。 aws.amazon.com/blogs/developer/stepfunctions-fluent-api
标签: aws-lambda aws-step-functions