使用 Step Functions 调用 Lambda - Amazon Step Functions
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 Amazon Web Services 服务入门

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

使用 Step Functions 调用 Lambda

Step Functions 可以控制某些Amazon直接来自 Amazon 状态语言的服务。有关使用的更多信息Amazon Step Functions及其集成,请参阅以下内容:

优化的 Lambda 集成与 Lambda 有何不同AmazonSDK 集成
  • 这些区域有:Payload响应的字段将从转义的 Json 解析为 Json。

  • 如果响应中的字段FunctionError,任务失败。

有关管理状态输入、输出和结果的更多信息,请参阅Step Functions 中的输入和输出处理

支持的 Amazon Lambda API:

下面这个Task调用 Lambda 函数的状态。

{ "StartAt":"CallLambda", "States":{ "CallLambda":{ "Type":"Task", "Resource":"arn:aws:states:::lambda:invoke", "Parameters":{ "FunctionName":"MyFunction" }, "End":true } } }

下面这个Task实现回调服务集成模式。

{ "StartAt":"GetManualReview", "States":{ "GetManualReview":{ "Type":"Task", "Resource":"arn:aws:states:::lambda:invoke.waitForTaskToken", "Parameters":{ "FunctionName":"get-model-review-decision", "Payload":{ "model.$":"$.new_model", "token.$":"$$.Task.Token" }, "Qualifier":"prod-v1" }, "End":true } } }

当您调用 Lambda 函数时,执行将等待函数完成。但是,可 Lambda 使用InvocationType参数,如下面这个例子所示:

{ "Comment": "A Hello World example of the Amazon States Language using Pass states", "StartAt": "Hello", "States": { "Hello": { "Type": "Task", "Resource": "arn:aws:states:::lambda:invoke", "Parameters": { "FunctionName": "echo", "InvocationType": "Event" }, "End": true } } }

Task返回结果,函数输出嵌套在元数据字典中。例如:

{ "ExecutedVersion":"$LATEST", "Payload":"FUNCTION OUTPUT", "SdkHttpMetadata":{ "HttpHeaders":{ "Connection":"keep-alive", "Content-Length":"4", "Content-Type":"application/json", "Date":"Fri, 26 Mar 2021 07:42:02 GMT", "X-Amz-Executed-Version":"$LATEST", "x-amzn-Remapped-Content-Length":"0", "x-amzn-RequestId":"0101aa0101-1111-111a-aa55-1010aaa1010", "X-Amzn-Trace-Id":"root=1-1a1a000a2a2-fe0101aa10ab;sampled=0" }, "HttpStatusCode":200 }, "SdkResponseMetadata":{ "RequestId":"6b3bebdb-9251-453a-ae45-512d9e2bf4d3" }, "StatusCode":200 }

或者,您可以通过直接在 “资源” 字段中指定函数 ARN 来调用 Lambda 函数。当您以这种方式调用 Lambda 函数时,您无法指定.waitForTaskToken,并且任务结果仅包含函数输出。

{ "StartAt":"CallFunction", "States":{ "CallFunction": { "Type":"Task", "Resource":"arn:aws:lambda:us-east-1:123456789012:function:HelloFunction", "End": true } } }

通过在中的中的 ARN 中指定相应选项,您可以调用特定的 Lambda 函数版本或别名。Resource字段中返回的子位置类型。请参阅 Lambda 文档中的以下内容:

有关在将 Step Functions 与其他配置时如何配置 IAM 的信息。Amazon服务,请参阅针对集成服务的 IAM 策略.