Azure Service Bus PeekLock仅在五秒后超时

sdm*_*mtr 8 php servicebus azure

我正在使用Service Bus在Azure上构建一个消息队列,正在使用PHP SDK,并且我遇到PeekLock消息超时的问题.

我可以使用PeekLock连接到队列并检索消息,但是,如果我花费超过五秒钟来删除消息,Azure会抛出404错误,指示锁已过期,并且消息将被放回队列中,就好像它从未被处理过.

这是我用过的一些测试代码的例子.在此示例中假设已加载Azure SDK并且已引用相应的命名空间.

<?php

  // .. load the sdk and namespaces etc ...

  $service_bus = ServicesBuilder::getInstance()->createServiceBusService([connection string goes here]);

  $options = new ReceiveMessageOptions();
  $options->setPeekLock();

  $message = $service_bus->receiveQueueMessage("[queue name here]", $options);
  print "message body is: " . $message->getBody();
  $service_bus->deleteMessage($message);

?>
Run Code Online (Sandbox Code Playgroud)

此代码执行完美 - 检索消息,显示正文,并删除消息.但是,如果我sleep(5);在deleteMessage()调用之前插入一个,Service Bus API将返回以下错误:

错误:提供的锁无效.锁已过期,或者消息已从队列中删除.

通过Azure门户创建队列时,我明确地将锁定超时时间设置为五分钟,并且我已经尝试在其他队列上设置不同的超时时间段,并且所有这些时间段仍然恢复为五秒到期.

我在这做错了什么?

问题解决了:

我收到了Azure支持团队的回复,他很快发现Azure门户没有持续创建队列时选择的锁定持续时间.默认的到期时间显然是五秒钟(虽然我在任何文档中找不到任何对此默认值的引用,这很烦人),这就是为什么它超时了.

所以无论如何,开发团队显然正在努力修复,一切都应该很快就会开始.

Nav*_*jan 0

实际上,默认的 MessageLock 持续时间默认为 60 秒(使用 C# sdk 创建时,我不确定 php sdk)...您可以将其增加到 5 分钟...您可以在创建 sb 队列时自定义它使用队列描述。