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

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

使用 Step Functions 调用 Amazon SQS

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

优化的 Amazon SQS 集成与 Amazon SQS 有何不同AmazonSDK 集成

没有针对请求响应要么等待具有任务令牌的回调集成模式。

支持的 Amazon SQS API:

注意

Step Functions 中任务的最大输入或结果数据大小有一个配额。当您向另一个服务发送或接收其他服务的数据时,这限制了您作为 UTF-8 编码字符串的 262,144 字节的数据。请参阅与状态机执行相关的配额

下面这个TaskAmazon Simple Queue Service (Amazon SQS)。

{ "StartAt": "Send to SQS", "States": { "Send to SQS": { "Type": "Task", "Resource": "arn:aws:states:::sqs:sendMessage", "Parameters": { "QueueUrl": "https://sqs.us-east-1.amazonaws.com/123456789012/myQueue", "MessageBody.$": "$.input.message", "MessageAttributes": { "my attribute no 1": { "DataType": "String", "StringValue": "attribute1" }, "my attribute no 2": { "DataType": "String", "StringValue": "attribute2" } } }, "End": true } } }

下面这个Task状态,然后等待返回 Amazon SQS 队列。请参阅等待具有任务令牌的回调

{ "StartAt":"Send message to SQS", "States":{ "Send message to SQS":{ "Type":"Task", "Resource":"arn:aws:states:::sqs:sendMessage.waitForTaskToken", "Parameters":{ "QueueUrl":"https://sqs.us-east-1.amazonaws.com/123456789012/myQueue", "MessageBody":{ "Input.$":"$", "TaskToken.$":"$$.Task.Token" } }, "End":true } } }

要了解有关在 Amazon SQS 中接收消息的更多信息,请参阅接收和删除消息中的Amazon Simple Queue Service 开发者指南.

有关将 Step Functions 与其他设备一起使用时如何配置 IAM 的信息Amazon服务,请参阅针对集成服务的 IAM 策略.