【问题标题】:Azure Service Bus Queue, Stuck Messages or Incorrect Message Count?Azure 服务总线队列、消息阻塞或消息计数不正确?
【发布时间】:2014-12-24 07:43:01
【问题描述】:
我正在使用 QueueDescription.MessageCount 来获取我的一个队列中剩余的消息数,但它显示为正数,但我无法接收任何消息。
我检查了活动队列和死信队列,但没有任何消息可接收。我尝试使用Recieve(); RecieveBatch(); onMessage(); - 都一样。
还有其他人看过吗?是消息卡住还是计数不正确。
谢谢
史蒂夫。
【问题讨论】:
标签:
azure
azureservicebus
azure-servicebus-queues
【解决方案1】:
我能想到的唯一原因是,如果您有received() 的消息,但没有调用complete() 或abandon()。在这种情况下,消息会“隐藏”一段特定的时间(默认为 30 秒)。在此期间,即使您收不到任何消息,您的消息计数也会为正数。
当 30 秒(默认值)过去后,消息变为可见,您可以再次receive() 它们。请注意,每次收到消息时,.DeliveryCount 属性都会递增,直到达到 10(默认值)并且消息被转储到死信子队列中。
请务必始终致电complete() 处理您已处理的任何消息。如果您希望它立即在队列中可供其他工作人员处理,请致电 abandon()。还要检查DeliveryCount 属性以确保您没有处理两次消息。 (如果您在调用complete() 之前花了很长时间处理消息并且到那时锁已被释放,则可能会发生这种情况。)