提供的锁无效

时间:2020-09-09 00:27:31

标签: azureservicebus azure-servicebus-queues

我正在使用Microsoft azure服务总线队列,每当在本地运行它时,都会出现以下2个错误:

无法从文件确定项目语言。请使用[--csharp,-javascript,-typescript,-java,-python,-powershell]之一

Microsoft.Azure.ServiceBus.MessageLockLostException:提供的锁无效。锁已过期,或者消息已从队列中删除,或者已由其他接收者实例接收。

这是我的代码:

public async Task Run([ServiceBusTrigger("<queue-name>", Connection = "queueConnectionString")] Message message, MessageReceiver messagereceiver, ILogger logger)
{
    var bodyJson = Encoding.UTF8.GetString(message.Body);
    var myMessage = JsonConvert.DeserializeObject<NewSubmissionMessage>(bodyJson);
    try
    {
        await _application.ProcessNewSubmission(myMessage);
        await messagereceiver.CompleteAsync(message.SystemProperties.LockToken);
    }
    catch (InvalidPackageException ex)
    {
        await messagereceiver.DeadLetterAsync(message.SystemProperties.LockToken, deadLetterReason: ex.Message);
    }
}

1 个答案:

答案 0 :(得分:0)

请检查您是否正在使用最新版本的扩展程序。如果不是4.1.1,请对其进行升级。 参考:https://github.com/Azure/azure-functions-servicebus-extension/issues/38

如果发生此类问题,建议使用服务总线资源管理器工具检查死信原因。以下文档提到与服务总线中的死字母相关的详细信息,以及导致消息死字母的各种原因: https://docs.microsoft.com/en-us/azure/service-bus-messaging/service-bus-dead-letter-queues

例如:如果问题是送达计数,则可以将MaxDeliveryCount增大到最大值(即10)

您可以尝试显式实现重试逻辑: https://docs.microsoft.com/en-us/azure/service-bus-messaging/service-bus-messaging-exceptions#messagelocklostexception https://github.com/jeffhollan/functions-csharp-queue-exponential/blob/master/ExponentialRetry.cs https://docs.microsoft.com/en-us/azure/architecture/best-practices/retry-service-specific#service-bus

以下是一些相关链接,您可以参考:

The lock supplied is invalid. Either the lock expired, or the message has already been removed from the queue-由于自动完成默认设置为true。将值更新为false后,即可解决。

https://github.com/MassTransit/MassTransit/issues/802#issuecomment-294879874 –从AMQP切换到NetMessaging协议后,问题已解决。

https://social.msdn.microsoft.com/Forums/azure/en-US/b86a64bb-cfcf-422b-a5fb-d831b7702c29/getting-an-exception-message-handler-encountered-an-exception?forum=servbus –使用“接收并删除”模式后,问题已解决。

但是,我们建议使用“ PeekLock”。

有关第一个错误,请参阅this