我的应用程序将消息发送到AWS SQS队列,以查找需要某种后台处理的作业。我的处理守护进程接收并处理这样的消息:
$result = $sqsClient->receiveMessage([
'QueueUrl' => \Myapp\Config::get('sqs.queue'),
'WaitTimeSeconds' => 20,
'MaxNumberOfMessages' => 1
]);
if (isset($result['Messages'])) {
foreach ($result->getPath('Messages/*/Body') as $messageBody) {
$handler = new \Myapp\Handler();
$handler->dispatch($messageBody);
}
}
这很好用,但我可以从SQS控制台看到我的脚本检索到的消息被放入"飞行中的消息"类别,然后一段时间后,他们会重新回到"可用的消息",然后我的脚本最终会再次接收它们。
如何从SQS队列中删除消息,或者更好地将它们标记为已完成?
答案 0 :(得分:10)
当您收到来自SQS队列的消息时,该消息(默认情况下)将在30秒后返回队列。这是为了处理消息处理崩溃并且需要再次处理消息的情况。
成功处理邮件后,使用deleteMessage
删除邮件。当您从receiptHandle
收到消息时,您需要消息中的receiveMessage
值才能删除该消息。
如果您的邮件的典型处理时间可能超过30秒,那么您可以配置队列以增加“返回队列”时间。这在SQS队列配置中称为“默认可见性超时”。
另请注意,Amazon SQS的运作方式如下:
答案 1 :(得分:2)
您需要在处理后删除邮件 - 这将被视为“标记已完成”;但是,如果下游的某些内容需要对此“已完成”的操作执行操作,那么我将“完成”消息发布到另一个SQS队列并且然后从传入队列中删除该消息并不罕见。通过这种方式,现在或将来的另一个过程可以采取在第一个工人完成其工作时需要完成的操作,即以分离的方式将这些过程链接在一起。
如果下游没有任何需要做的事情,只需删除即可。