我配置了一个简单的 SQS,并且我想一次处理 4 条消息。 在我的测试中,它有2条“可用”消息。当我收到消息时,一次只会产生 1 。我做错了什么?
sqs = boto3.client('sqs') response = sqs.receive_message( QueueUrl=queue_url, MaxNumberOfMessages=4 )
您没有做错任何事,这种行为是正常的。
这是由于 SQS(以及大多数 AWS 服务)的分布式性质造成的。基本上,并非所有节点都具有所有可用消息,并且您与之交谈的节点可能会返回 0 到 MaxNumberOfMessages 之间的任何数字(如果有可用的话)。要在一次调用中实际接收多条消息,您需要在队列中有 100 或 1000 多条消息,即使如此,您也可能会运气不好,收到的消息很少。
来自文档:
您没有做错任何事,这种行为是正常的。
这是由于 SQS(以及大多数 AWS 服务)的分布式性质造成的。基本上,并非所有节点都具有所有可用消息,并且您与之交谈的节点可能会返回 0 到 MaxNumberOfMessages 之间的任何数字(如果有可用的话)。要在一次调用中实际接收多条消息,您需要在队列中有 100 或 1000 多条消息,即使如此,您也可能会运气不好,收到的消息很少。
来自文档: