AWS提供一种名为ReceiveMessage的API,可用于从FIFO队列中接收消息。每当消息到达队列中时,该消息将被赋予一个消息组ID。当多个消息具有相同的消息组ID时,AWS Console如何接收它们?
AWS控制台使用long-polling来接收消息。在等待消息时,控制台将持续监听消息队列,直到消息到达队列。在接收到消息时,控制台将在请求的时间范围内返回所有相同消息组ID的消息。
以下是一个使用AWS SDK for Java中的ReceiveMessage API的示例代码,该示例获取名称为“test.fifo”的FIFO队列中的所有消息:
AmazonSQS sqs = AmazonSQSClientBuilder.standard().withRegion(Regions.US_EAST_1).build();
ReceiveMessageRequest receiveMessageRequest = new ReceiveMessageRequest(queueUrl)
.withWaitTimeSeconds(20)
.withMessageAttributeNames("All")
.withMaxNumberOfMessages(10);
ReceiveMessageResult receiveMessageResult = sqs.receiveMessage(receiveMessageRequest);
List messages = receiveMessageResult.getMessages();
for (Message message : messages) {
System.out.println("Message");
System.out.println(" MessageId: " + message.getMessageId());
System.out.println(" ReceiptHandle: " + message.getReceiptHandle());
System.out.println(" message group ID: " + message.getMessageGroupId());
System.out.println(" Body: " + message.getBody());
for (Map.Entry entry : message.getMessageAttributes().entrySet()) {
System.out.println(" " + entry.getKey() + ": " + entry.getValue());
}
}
该代码将等待最长20秒以获取最多10条消息,并使用All参数检索所有消息属性。接收到的每条消息都将显示消息ID、接收处理、消息组ID和消息正文。