繁体   English   中英

处理后从SQS队列中删除消息

[英]Deleting messages from SQS queue after processing

我的应用程序将消息发送到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队列中删除消息,或者更好地将它们标记为已完成?

当您从SQS队列收到消息时,该消息将(默认情况下)在30秒后返回队列。 这是为了处理消息处理崩溃并且需要再次处理消息的情况。

成功处理消息后,使用deleteMessage删除消息。 当您从receiveMessage收到消息时,您需要来自消息的receiptHandle值才能删除消息。

如果消息的典型处理可能需要30秒以上,那么您可以配置队列以增加“返回队列”时间。 这在SQS队列配置中称为“默认可见性超时”。

另请注意,Amazon SQS的工作方式如下:

  1. 与将它们添加到队列的方式相比,可以无序地接收消息
  2. 消息可能会被接收两次,因此请允许消息处理器处理这些情况

您需要在处理后删除消息 - 这将被视为“标记已完成”; 但是,如果下游的某些内容需要对此“已完成”的操作执行操作,那么我将“完成”消息发布到另一个SQS队列并且然后从传入队列中删除该消息并不罕见。 通过这种方式,现在或将来的另一个过程可以采取在第一个工人完成其工作时需要执行的操作,即以分离的方式将这些过程链接在一起。

如果没有任何下游需要完成,只需删除它就足够了。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM